

**APPLICATION** SPECIFIC LOGIC PRODUCTS DATA BOOK 1986

**Application Specific** Logic Products Division

\$10.00

APPLICATION SPECIFIC LOGIC PRODUCTS DATA BOOK

1986

VLSI TECHNOLOGY, INC.



|                                       | APPLICATION<br>SPECIFIC LOGIC<br>PRODUCTS<br>DATA BOOK<br>1986 |
|---------------------------------------|----------------------------------------------------------------|
|                                       |                                                                |
|                                       |                                                                |
|                                       |                                                                |
|                                       |                                                                |
|                                       |                                                                |
|                                       |                                                                |
|                                       |                                                                |
|                                       |                                                                |
| · · · · · · · · · · · · · · · · · · · |                                                                |
|                                       |                                                                |
|                                       |                                                                |
|                                       |                                                                |
|                                       |                                                                |
|                                       |                                                                |

Application Specific Logic Products Division

The information contained in this document has been carefully checked and is believed to be reliable. However, VLSI Technology, Inc., makes no guarantee or warranty concerning the accuracy of said information and shall not be responsible for any loss or damage of whatever nature resulting from the use of, or reliance upon, it.

This document does not in any way extend VLSI Technology, Inc.'s warranty on any product beyond that set forth in its standard terms and conditions of sale. VLSI Technology, Inc., reserves the right to make changes in the products or specifications, or both, presented in this publication at any time and without notice. © 1986 VLSI Technology, Inc. Printed in U.S.A.



# CONTENTS

### SECTION 1 INTRODUCTION

### PAGE NUMBER

| General                                              | 1–3 |
|------------------------------------------------------|-----|
| Megacells                                            | 1–3 |
| Megacell-Based Design Rationale                      | 1–4 |
| Current Family of Megacells                          | 1–4 |
| Designing a Circuit Using Megacells                  | 1–4 |
| Using VLSItest During the Design Phase               | 1–4 |
| Additional Logic for Test Simplification             | 1–4 |
| Using VLSItest Software to Help Create Test Programs | 1–4 |
| Defining the Test Program Flow                       | 1–6 |
| Simulation and Test Program Generation               | 1–6 |
| Completing the Design                                | 1–7 |
| VL68C45 Megacell                                     | 1–7 |
| Summary                                              | 1–7 |
| Data Book                                            | 1–7 |

### SECTION 2 ORDERING AND PACKAGING INFORMATION

| General                                               | 2–3  |
|-------------------------------------------------------|------|
| Package Considerations                                | 2–4  |
| Dual-In-Line Packages                                 | 2–4  |
| Small-Outline Integrated Circuits                     | 2–4  |
| Chip Carriers                                         | 2-4  |
| Chip-On-Board Mounting                                | 2–5  |
| Pin Grid Array                                        | 2–5  |
| Flatpack                                              | 2–5  |
| System Considerations                                 | 2–5  |
| Conclusion                                            | 2–6  |
| Thermal Considerations                                | 2-6  |
| Package Outlines                                      | 2–7  |
| 18-Pin Ceramic Side-Brazed Dual In-Line Package (DIP) | 2–7  |
| 18-Pin Plastic Dual In-Line Package (DIP)             | 2–7  |
| 20-Pin Ceramic Side-Brazed Dual In-Line Package (DIP) | 2–8  |
| 20-Pin Plastic Dual In-Line Package (DIP)             | 2–8  |
| 24-Pin Plastic Dual In-Line Package (DIP)             | 2–9  |
| 28-Pin Ceramic Side-Brazed Dual In-Line Package (DIP) | 2-9  |
| 28-Pin Plastic Dual In-Line Package (DIP)             | 2-10 |
| 28-Pin Plastic Leaded Chip Carrier (PLCC)             | 2–10 |
| 40-Pin Ceramic Side-Brazed Dual In-Line Package (DIP) | 2-11 |
| 40-Pin Plastic Dual In-Line Package (DIP)             | 2-11 |
| 44-Pin Plastic Leaded Chip Carrier (PLCC)             | 2-12 |
| 48-Pin Ceramic Side-Brazed Dual In-Line Package (DIP) | 2–12 |
| 48-Pin Plastic Dual In-Line Package (DIP)             | 2–13 |
| 64-Pin Ceramic Side-Brazed Dual In-Line Package (DIP) | 2–13 |
| 64-Pin Plastic Dual In-Line Package (DIP)             | 2–14 |
| 68-Pin Plastic Leaded Chip Carrier (PLCC)             | 2–14 |
| 84-Pin Leadless Chip Carrier (LCC)                    | 2–15 |
| 84-Pin Plastic Leaded Chip Carrier (PLCC)             | 2–16 |
| 149-Pin Ceramic Pin Grid Array (PGA)                  | 2–17 |
|                                                       |      |

### SECTION 3 PROCESSORS AND COPROCESSORS

| VL65C02 • VL65NC02 CMOS 8-Bit Microprocessor Family   | 3–3  |
|-------------------------------------------------------|------|
| VL65C816 • VL65C802 CMOS 16-Bit Microprocessor Family | 3–17 |
| VL86C010 32-Bit Reduced Instruction Set Computer      | 3–41 |
| VL82C389 Message-Passing Coprocessor                  | 3–55 |



## CONTENTS

5–3 5–9

### SECTION 4 PERIPHERALS

| VL16160 "Raster Op" Graphics/Boolean Operation ALU                            | 4-3   |
|-------------------------------------------------------------------------------|-------|
| VL1772-02 5¼-inch Floppy Disk Controller/Formatter                            | 4-11  |
| VL2793 • VL2797 Floppy Disk Formatter/Controller Family                       | 4-33  |
| VL4500A Dynamic RAM Controller                                                | 4-55  |
| VL4502 Dynamic RAM Controller                                                 | 4-69  |
| VL6522 • VL65C22 Parallel Interface/Timer                                     | 4-83  |
| VL6765 Double-Density Floppy Disk Controller                                  | 4-101 |
| VL6845R/E • VL68C45R/S CRT Controller Family and VMC68C45 Megacell Design Kit | 4-127 |
| VL82C37A CMOS Direct Memory Access (DMA) Controller                           | 4-149 |
| VL82C54 Programmable Interval Timer                                           | 4–167 |
| VL82C59A Programmable Interrupt Controller                                    | 4-168 |
| VL82C84A Clock Generator and Driver                                           | 4-169 |
| VL82C88 CMOS Bus Controller                                                   | 4-170 |
| VL85C81 CMOS Clock Generator and Controller                                   | 4–171 |
| SECTION 5 SIGNAL PROCESSING PRODUCTS                                          |       |

# 

### SECTION 6 DATA COMMUNICATIONS PRODUCTS

| VL16C450 • VL82C50A • VL82C50 Asynchronous Communications Element | <br>6–3  |
|-------------------------------------------------------------------|----------|
| VL1935 Synchronous Data Line Controller                           | <br>6–13 |
| VL2661 Enhanced Programmable Communication Interface              | <br>6-31 |
| VL6551 • VL65C51 Asynchronous Communication Interface Adapter     | <br>6-45 |
| VL8530 Serial Communications Controller                           | <br>6-57 |
| VL85C35 Enhanced Serial Communications Controller                 | <br>6–79 |
|                                                                   |          |
| SECTION 7 TELECOMMUNICATIONS PRODUCTS                             |          |
| VL7C103 300 Baud Modem                                            | <br>7–3  |
| VL7C211 212A/V.22 Modem Filter                                    | <br>7-11 |
| VL7C212A 300/1200 Bit per Second Modem                            | <br>7-25 |
| VI 80C75 T1 Interface                                             | 7-33     |

### SECTION 8 SALES OFFICES, DESIGN CENTERS, AND DISTRIBUTORS



# NUMERICAL INDEX

| DEVICE<br>NUMBER                                                                                      | DESCRIPTION                                                                                                                                                                                                                                                                     | PAGE<br>NUMBER                                                  |
|-------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------|
| VL16160<br>VL16C450                                                                                   | Raster Op Graphics/Boolean ALU         Asynchronous Communications Element                                                                                                                                                                                                      | 4–3<br>6–3                                                      |
| VL1772-02                                                                                             | Floppy Disk Controller                                                                                                                                                                                                                                                          | 4–11                                                            |
| VL1935                                                                                                | Synchronous Data Line Controller                                                                                                                                                                                                                                                | 6–13                                                            |
| VL2010<br>VL2044                                                                                      | 16 × 16 Multiplier/Accumulator with Preload                                                                                                                                                                                                                                     | 5–3<br>5–9                                                      |
| VL2661                                                                                                | Enhanced Programmable Communications Interface                                                                                                                                                                                                                                  | 6–31                                                            |
| VL2793<br>VL2797                                                                                      | Single-Sided Floppy Disk Formatter/Controller                                                                                                                                                                                                                                   | 4–33<br>4–33                                                    |
| VL4500A<br>VL4502                                                                                     | 64K Dynamic RAM Controller                                                                                                                                                                                                                                                      | 4–55<br>4–69                                                    |
| VL65C02<br>VL65NC02<br>VL6522<br>VL65C22<br>VL65C21<br>VL65C51<br>VL65C802<br>VL65C816                | 8-Bit CMOS Microprocessor<br>8-Bit CMOS Microprocessor<br>Parallel Interface/Timer<br>CMOS Parallel Interface/Timer<br>Asynchronous Communication Interface Adapter<br>Asynchronous Communication Interface Adapter<br>16-Bit CMOS Microprocessor<br>16-Bit CMOS Microprocessor | 3–3<br>3–3<br>4–83<br>4–83<br>6–45<br>6–45<br>3–17<br>3–17      |
| VL6765                                                                                                | Double-Density Floppy Disk Controller                                                                                                                                                                                                                                           | 4–101                                                           |
| VL6845R/E<br>VL68C45R/S                                                                               | CRT Controller                                                                                                                                                                                                                                                                  | 4–127<br>4–127                                                  |
| VL7C103<br>VL7C211<br>VL7C212A                                                                        | 300 Baud Modem         1200 Baud Filter           300/1200 Bit-per-Second Modem                                                                                                                                                                                                 | 7–3<br>7–11<br>7–25                                             |
| VL80C75                                                                                               | T1 Interface                                                                                                                                                                                                                                                                    | 7–33                                                            |
| VL82C37A<br>VL82C389<br>VL82C50<br>VL82C50A<br>VL82C54<br>VL82C59A<br>VL82C59A<br>VL82C84A<br>VL82C88 | CMOS Direct Memory Access Controller                                                                                                                                                                                                                                            | 4-149<br>3-55<br>6-3<br>6-3<br>4-167<br>4-168<br>4-169<br>4-170 |
| VL8530<br>VL85C35<br>VL85C81                                                                          | Serial Communications Controller<br>Enhanced Serial Communications Controller<br>CMOS Clock Generator and Controller                                                                                                                                                            | 6–57<br>6–79<br>4–171                                           |
| VL86C010                                                                                              | 32-Bit Acorn RISC Machine (ARM)                                                                                                                                                                                                                                                 | 3-41                                                            |
| VMC68C45                                                                                              | Megacell Design Kit                                                                                                                                                                                                                                                             | 4–127                                                           |





| SECI  |
|-------|
| INTRO |
| _     |
| -     |
| _     |
| _     |
| _     |
| _     |
|       |
| _     |
| -     |
| -     |
| <br>- |
| _     |
| _     |
|       |
|       |
| -     |
| <br>_ |
| -     |
| -     |
| <br>_ |
| -     |
|       |
| ~     |

SECTION 1 INTRODUCTION

Application Specific Logic Products Division





### GENERAL

The primary business objective of VLSI Technology, Inc., (VLSI) is to provide systems designers with total application-specific integrated circuit (ASIC) solutions. To accomplish this, it has created a unique blend of expert design tools, leading-edge process technologies, state-of-the-art fabrication facilities, and a wide range of products, including a variety of "catalog" devices.

The Application Specific Logic Products Division of VLSI Technology is responsible for the manufacture and marketing of a diverse logic-based product line that encompasses both innovative and proven, well-established catalog devices. This line includes microprocessors and coprocessors, peripheral circuits, digital signal processing devices, and products for data communications and telecommunications applications.

Unlike other suppliers of such devices, however, VLSI is also a recognized leader in ASICs. As such, it not only possesses the design, process, and fabrication capabilities necessary to produce the highest-quality off-the-shelf components, but is also able to treat its logic products as an integral part of a complete solution. One of the primary vehicles for accomplishing this is the megacell; the functions represented by individual devices can be implemented as megacells in VLSI's software libraries and used for semicustom circuit design, and functions developed as megacells for specific applications can be turned into catalog products.

### MEGACELLS

The megacell is a relatively new concept in the world of IC and system design. As such ASIC companies as VLSI Technology offer better tools for IC design, simulation, and testing, it becomes necessary for systems manufacturers to design custom ICs to keep up with their competition. Megacells help decrease design time by providing large building blocks that are equivalents of standard. off-the-shelf products. By using megacells and VLSI's design tools. manufacturers can have a custom IC design capability without all of the normal custom development costs.

The VLSI Technology family of megacells represents commonly used peripherals that are good candidates for integration as parts of customer-driven designs, which can be either customer-specific or market-specific. In customer-specific designs, it is possible, for example, to combine these integration elements with other megacells and logic to become single-chip equivalents of computer systems that are already in production. This increased level of integration provides cost and space reductions that can keep the system designs competitive. In a marketspecific design, upward-compatible enhancements that meet the needs of many customers can be added and the device offered as a new standard product.

## INTRODUCTION

VLSI's megacells are designed to have a fixed height and variable widths, offering the best trade-off between unusable internal space and placement ease. As shown in Figure 1, they can be configured to make a very dense final design with a minimum of wasted silicon real estate.

Of equal importance with the physical layout format of the cells is the structure of the interconnect bus. This bus must be generic enough to allow a wide variety of functions to be connected uniformly and efficiently, and must be fast enough to not itself become a limiting factor as system performance increases.

The internal structure of the bus created by VLSI for use with its megacells contains an m-bit data bus and an n-bit address bus, both of which are expandable in width to accommodate changes in system requirements. The bus operates synchronously at a rate of 3 million transfers a second, which is equivalent to the performance of a 10 MHz 8086 or a 12 MHz 68000 microprocessor. The bus definition allows for internal access times of 50 ns and cycle times in the 200 ns range. With standard pad drivers. external loads can be driven while supporting a 3 MHz bus frequency: faster speeds can be obtained by using faster pad drivers. To create a standard product from a megacell, an interface circuit is incorporated that exactly matches the slower timing of the external bus to the internal bus.

FIGURE 1. VLSI TECHNOLOGY MEGACELLS ARE ALL OF A FIXED HEIGHT, WITH VARIABLE WIDTHS.





### MEGACELL-BASED DESIGN RATIONALE

There are many reasons why megacells make sense for new designs, including reduced board space, lower power, increased reliability and reduced design times.

Typical applications that can benefit from the use of megacells are those that contain three or four LSI components and a handful of "glue" components. All of these components can be combined into a single component if the functions can be partitioned into logical groups with a reasonable number of I/O pins. In this type of application, the total pin count might be reduced from 300 pins for a discrete solution to less than 100 pins, and the circuit board area reduced from approximately 20 square inches to 2 square inches.

The power consumption of megacell designs can be very small in comparison with the HMOS designs they replace, since all of the VLSI Technology megacell family is implemented in high-speed, low-power, 2-micron CMOS technology. In addition, because several functions can be put on one piece of silicon, the interconnect capacitance and inductances are minimized, thereby reducing the power to a fraction of what was needed in previous designs.

The reliability of a megacell-based design is typically better than the collection of discrete components it replaces because there are fewer pins, fewer bonding wires and lower total power consumption. In most systems, the largest contributor to reliability problems is IC pin connections, with such other factors as die temperature and die size being secondary. The more functional blocks that can be combined on a single piece of silicon, the fewer the number of interconnections that have to be bonded to package pins. resulting in higher overall reliability of the component and system using it.

Since megacells can be used as high-level building blocks, overall design times can be reduced significantly by taking existing designs using standard products and integrating additional support logic directly onto the chip. An example of this technique would be the integration of a VL68C45 CRT controller with a memory interface and video shift registers to form a single-chip video adapter. An additional option might be to include character ROMs or RAM arrays, although the addition of these commodity components is not always cost-effective.

#### CURRENT FAMILY OF MEGACELLS

Megacells are designed by very carefully studying the data sheets and systems implementations of the original part vendors, but an important part of validating a megacell design is to subject it to many different hardware and software environments. Only after a part has been tested in several applications can a vendor feel confident that the megacell exactly emulates the original function, including all of the undocumented "features." The VLSI Technology philosophy is to offer members of the megacell family as standard products as well as cells so that this validation can take place very quickly after the introduction of the standard product. Since customer-specific design times typically take from 2 to 4 months, megacell designs can be started before the standard product validation has been done. This lead time allows customers to get a head start introducing designs.

### DESIGNING A CIRCUIT USING MEGACELLS

The design process is started by using a megacell schematic "icon" as part of the schematic entry of the user's design. Provided with the megacell icon is a data sheet detailing the internal timing requirements of the megacell. The designer works from this data sheet as if using an off-the-shelf standard product, except that the logic and timing of the bus are somewhat easier to use.

# INTRODUCTION

# USING VLSItest DURING THE DESIGN PHASE

When the schematic entry of the design is complete, the designer uses a test language assistance program (VLSItest) to capture a set of simulation vectors that can be used to test the design after silicon has arrived. Once the designer is satisfied that the vector set is sufficient to cover all possible stuck faults, a final test program can be compiled through this program. The output from this program is a test program containing SETF statements that can be easily moved onto an industry-standard tester, such as a Sentry tester system.

### ADDITIONAL LOGIC FOR TEST SIMPLIFICATION

In all cases, some additional logic will be necessary to facilitate testing the megacells. This additional logic consists of multiplexers on pins to allow all of the connections of the megacell to be accessed from the periphery of the circuit. This dictates that all designs be contained in packages having at least as many pins as the most pin-intensive megacell used internally. To enable the test mode, an illegal condition on the interface is often used, such as Read Strobe and Write Strobe being asserted together while the chip is selected. This would normally never occur in an application, so it is a safe combination to use. When enabled, the I/O pads of a specific megacell are connected to the I/O pins of the component, and the standard product test program run to verify the functionality of the core.

#### USING VLSItest SOFTWARE TO HELP CREATE TEST PROGRAMS

VLSItest is a software package that eliminates the need for the design engineer to be an expert in testers and testing. The designer works in a test language called VLSI Test Language (VTL), which allows simultaneous development of the circuit design and test program, providing notification early in the design stages of when tester-specific details



/LSI TECHNOLOGY, INC.

affect the testability of the design. Through the test language, designers can create a file describing the physical characteristics, timing, stimulus patterns and expected responses of a circuit under development (Figure 2). The remaining software translates the description into commands that run the simulation, verify the expected response. and store requested reponse values predicted from a simulator. Finally, VLSItest generates a complete test program that includes all specifications for the timing generators, strobes, and registers, all patternloading, requested dc parametric and summary test routines, and the test vectors needed to test the circuit functionality.

Besides identifying tester limitations associated with the test program, the software suggests ways to work around them. In that way, design engineers can become familiar with tester limitations and make the optimum design-vs.-testing trade-off. When the testability of a circuit becomes a problem, the design engineer can add additional circuitry to help out. Common practice is to break up long counter strings to reduce the number of states required to exercise each individual stage.

The test vectors generated by the software have a one-to-one correspondence with the vectors used during the simulation, so the information normally lost during postprocessing is retained. Another benefit is that, since a tester is not needed to develop the test program and initially debug it, the test system is available for production time and work can be done during normal hours.

To interface with specific testers, the software needs routines that contain tester-specific information. These routines also identify portions of the test or simulation language descrip-

## INTRODUCTION

tion that can not be executed by the tester, simplifying the task of making portable test software. Interface routines are currently written in Xidak's Mainsail language for both VLSI's simulator and the Sentry Series 7, 10 and 20 testers.

When defining an IC, designers can define the stimuli and the expected responses through the test language, creating modules that describe aspects of the circuit's functions or dc test conditions. The resulting circuit description, which is independent of tester or simulator characteristics, is combined with the tester-specific and simulator-specific routines. Since the circuit description contains a complete set of operational parameters, all information necessary to create a data sheet is present. Since that information actually drives the simulator and develops the test program, it always remains up-to-date.







### DEFINING THE TEST PROGRAM FLOW

Several types of software modules are required to create a complete test description. Designers use the first module, MAIN, both to describe the overall flow of the test and to initialize the test software for execution. The contents of the MAIN module declare the duration of a test, select the required parameter modules, and specify their order of execution. The MAIN module partitions the testing into a number of steps that can be easily understood from a high level.

The DURATION statement determines the length of the tester cycle, and normal-time selects the timing parameter module of that name. The WRITE commands place remarks in the test program file for documentation purposes.

The physical characteristics of the IC are defined through the pin definition (PINDEF) module, which contains a declaration of the number of circuit pins and statements that the test software uses to identify pins during testing. Those pin-definition statements also define pin type (input, output, bidirectional, power, etc.). In addition, the module may define the device type and state whether it is static or dynamic. Labels for each element of the pin list can specify such pin types as input, output, bidirectional, power, ground, threestate, open-drain, open-source, or no-connection.

Minimum, nominal, and maximum timing parameters are defined in the TIMEPARAM module. Designers can test the circuit under different timing conditions by defining multiple modules and assigning each module its own identifier.

An additional module, EDGETIME, creates transition edges using the parameters defined by TIMEPARAM. These edges determine when the stimulus values are placed on the input pins and when the response values are measured during each test cycle, indicating such timing points as when outputs should be sampled and when inputs should be changed. For example, to create a clock that remains LOW for 80 ns, HIGH for 100 ns, and repeats every 200 ns would require the definition of four edges. The first edge would be at 0 ns, the second at 80 ns, the third at 180 ns, and the fourth at 200 ns. The last edge defines the period of the cycle and is also used for the duration declaration.

For each test cycle, the CYCLE module describes the stimulus for input pins and the response for output pins. If parameter values are included within parentheses in the module heading, a variety of values can be placed on the input pins. Each time the module is called, the appropriate values are passed to it. This module takes transition edges from the EDGETIME module and determines when to apply stimulus values to the I/O pins and when to measure outputs during each test cycle. CYCLE statements in the modules specify whether a specific pin is to be stimulated or measured. A transition edge at a pin may be specified by "@" time. If not specified, the stimulus values are placed on the pin at the beginning of the cycle and the responses are measured at the end of the cycle.

With FUNCTIONTEST modules, the designer partitions the test into functional blocks or initialization procedures, particularly if the sections are to be used more than once. The first DCPARAM statement sets the minimum and maximum measurement values as well as the source that creates them (current or voltage). Defaults are provided if exact values have not been selected. An important attribute of this module is that some portions can be used more than once. These modules are executed when called by the MAIN routine or other FUNCTIONTEST routines. They may contain WHILE and other looping constructs to provide a means of conditionally executing statements.

## INTRODUCTION

#### SIMULATION AND TEST PROGRAM GENERATION

As the software generates the test program, it draws on the stimulus and response values to select each pin's timing generators and strobes on the basis of the value of the pin before the cycle starts, the number of transitions occuring on the pin during the cycle, and if the pin is to be an input or output during the cycle.

The selection of mask registers is determined by the state of the registers at the start of the cycle and the pins that have been activated during the cycle. The appropriate values are inserted into a test vector, which is stored in a vector file with the register set or enabling commands. Before storing the test vector, the software attempts to take advantage of any vector compaction capability of the tester.

After the test language is used to create the modules, the resulting description file is loaded into VLSItest, which parses it and ensures that its syntax is correct. While parsing, the software creates a data base from the physical characteristics described in the PINDEF module and from the identifiers used throughout the circuit description. After the program is properly compiled, testing may begin.

The test language itself possesses all the power and flexibility needed to efficiently develop test programs. All variables and constants are 32-bit values that may be manipulated on a bit-by-bit basis by a variety of familiar operators, such as AND, OR, and XOR. Additionally, the language's looping constructs present a compact means of conditionally executing a series of tests.



### COMPLETING THE DESIGN

Test engineering effort is still required when using this process, but the time spent can be a matter of only a few weeks, rather than the several-week period traditionally associated with creating a test program for a new product.

When simulation is complete and the design works satisfactorily, the lavout process can begin. In most cases, designers are interested in minimizing design time and associated costs, so they pick standard cells for the additional blocks of logic that will surround the megacell cores. Cells are individually compiled, placed and routed to create blocks of logic until the entire nonmegacell portion of the design is complete. For the best lavout efficiency, the additional logic is either put into a block having the same height as a megacell, or it is put around the megacells to fill in the voids. When each portion of the design is completed, these blocks can be placed and interconnected using a tool called VLSICOMPOSE. which is a top-level composition editor. This editor assists in interconnecting blocks of cells and optimizing both the placement and interconnection of cells. The overall goal of placing blocks to form the chip is to get the ratio of the X and Y dimensions (the aspect ratio) as close to 1:1 as possible. The resulting square die gives the packaging engineer the most flexibility in package selection.

When the entire layout process is complete, a netlist of interconnections is extracted from the physical data base to allow comparison of what was intended to be with what actually was implemented. Once the extraction is complete and the netlist comparison between schematic and layout is successful, the device can be resimulated in software with more accuracy, since values of expected capacitance are extracted along with the connectivity information. Finally, the layout is checked for design rule violations using the design rule checker (DRC) program.

When all of this has been successfully completed, the data base is sent to a design center, where the actual physical layout of the megacells is included in the data base. When everything checks out properly, a mask set is created and silicon is started. From this point, the fabrication time typically takes 8 weeks for the first-pass prototypes.

### VL68C45 MEGACELL

The first VLSI Technology megacell to be available both in standard product form and megacell format is the VL68C45 CRT controller. This part is the video timing interface component used in the IBM PC and is commonly used in low-cost video adapters for other personal computers as well. This megacell has been implemented in 2-micron CMOS technology and offers character clock rates of up to 4.5 MHz and bus clock rates at the full bus speed of 3 MHz. The version of the 6845 desired may be strap-selected to choose from the Motorola R or R1 versions, the Hitachi S version or the Synertek E version. In addition to the standard 6845 features, up to 16 bits of display memory may be used, the vertical sync pulse width is programmable and the vertical row counter is programmable to be 7, 8 or 9 bits. In addition to a larger video address space, early address lines are provided to eliminate pipeline stages in CRT adapter designs. Most control signals are the same as those offered on the standard 6845. but additional control signals are provided for ease of interfacing, three-stating address buses and option selection.

## INTRODUCTION

#### SUMMARY

Megacells offer a way to guickly design chips that replace today's board-level functions, while at the same time offering competitive costs, increased reliability, increased performance and reduced board space. The design process requires a wide range of design tools, including standard cells, cell compilers, simulators, routers, test program generators, and libraries of designs. VLSI Technology, Inc., specializes in offering these kinds of tools in addition to complete wafer services to provide a total solution to systems designers.

### DATA BOOK

This data book presents a complete technical description of the VLSI Technology, Inc., Application Specific Logic Products Division product line. Where devices have been fully characterized, either by VLSI Technology or by one of its partners, specific information is presented in the form of data sheets. Information on partially characterized devices, and on devices currently under development, is in the form of product briefs. More complete data can be obtained on any device from the Logic Products Division Application Department.





| SECTION 2<br>ORDERING<br>AND<br>PACKAGING<br>INFORMATION |
|----------------------------------------------------------|
|                                                          |
|                                                          |
|                                                          |

Application Specific Logic Products Division





aa9999

### GENERAL

VLSI Technology, Inc., Logic Products devices are available in a variety of plastic and ceramic packages, including chip carriers and pin grid arrays, and in different temperature ranges. Specific information on the packages and temperature ranges for particular devices is coded into the part number portion of the order information included in each data sheet of sections 3 through 7.

 RC9999 is a ROM code number.

 SL9999 is a special lead number.

 SM9999 is a special marketing number.

 SM9999 is a special lead number.

 SM9999 is a special test number.

 ST9999 is a special test number.

 Store a 48-hour dynamic burn-in.

e

TEMPERATURE CODE

SPECIAL NUMBER CODE

ENVIRONMENTAL GRADE CODE

PACKAGE TYPE CODE

M indicates the military operating temperature range of from -55°C to +125°C.

C indicates a ceramic side-brazed dual in-line package (ceramic DIP).

C indicates the commercial operating temperature range of from

indicates an industrial operating temperature range of from

D indicates a cerdip.

0°C to +70°C.

-40°C to +85°C.

L

This information is organized as:

bb

VI 9999999

- G indicates a ceramic pin grid array (PGA).
- L indicates a JEDEC type-B leadless chip carrier (LCC).
- P indicates a plastic dual in-line package (plastic DIP).

Q indicates a plastic leaded chip carrier (PLCC).

The package forms indicated by the codes are illustrated in the outline drawings contained within this section.

## PART NUMBER EXAMPLE

The part number VL68C45R–23PCSS0001 would indicate a CMOS revision R version of the 6845 CRT controller having a 2 MHz bus clock and a 3 MHz character clock, housed in a plastic DIP, operating over the commercial temperature range, and tested to a special specification (#0001).



### PACKAGE CONSIDERATIONS DUAL IN-LINE PACKAGES

The dual in-line package (DIP) has been in high-volume production for nearly twenty years, and is estimated to have been the package of choice for over 80% of all integrated circuits shipped in 1985. Some 1986 usage estimates are as high as 18 billion units worldwide. Generally, devices in DIPs can be purchased in two types of ceramic (cerdip and sidebrazed) and in the very-familiar molded plastic package. Over 85% of all DIPs, or over 12 billion, sold worldwide in 1985 were plastic.

The ceramic side-brazed package is relatively expensive and is frequently imported. It has excellent mechanical characteristics, including the ability to survive extreme temperatures, salt water, and corrosive atmospheres. However, as the cost of the integrated circuit it houses becomes less and less expensive. the relative cost of the ceramic DIP becomes a major concern. In a large number of applications, this package is several times more expensive than the chip within it. As would be expected, this package is very popular in military electronics and in other potentially harsh mechanical environments. The side-brazed package, while representing less than 2% of all DIP packages shipped in 1985, represents a higher percentage of DIP revenue, due to its comparatively high average selling price (ASP).

The cerdip is a "sandwich" of two ceramic parts that are joined together by a cement-like epoxy. The die itself is mounted on a lead frame, and enjoys many of the cost economies associated with this approach. The cerdip has some of the mechanical advantages of the side-brazed ceramic at a lower cost. The cerdip represented about 14% of all DIP shipments in 1985.

The plastic DIP has been the catalyst for the computer revolution. The dramatic reduction in the cost of microprocessors, microprocessor peripherals, communications devices, and memories has been passed along to the manufacturers and the final users because plastic packaging has remained extremely inexpensive. In addition, reliable automated 16-pin and 14-pin DIP insertion equipment has dramatically reduced manual "board stuffing" costs of DIPs. The plastic DIP itself is easy to manufacture. The die is mounted on a copper-alloy lead frame and the plastic material is molded around it. It is usually branded by a printing method with an epoxy-based ink but, recently, laser-scribing the number into the plastic body is gaining popularity, reducing costs even further.

Mechanically, the DIP has proven to be an extremely utilitarian package in most applications. Its short, stiff leads on 2.54 mm (0.1 inch, or 100 mil) centers allow reasonably easy insertion for both test and production by both manual and automatic techniques. While more expensive DIPs are placed in sockets, the overwhelming majority are soldered directly into the printed circuit board. The 64-pin DIP, the largest DIP in high-volume production, is used to house VLSI's VL2010 and VL2044 Multiplier/Accumulators. DIP configurations with higher pin counts tend to exhibit unacceptable mechanical problems, such as extremely high insertion and extraction forces.

DIPs are available, in even-pin-count steps, in packages as low as two pins. A variation of the DIP that has gained some acceptance is the SIP. or single in-line package. The SIP, mounted lving on its edge, uses very little printed circuit board space and frequently contains a number of memory die in high-density memory applications. However, as desirable as the SIP may seem, it is not the major evolutionary path of the DIP. The SIP allows little air circulation for cooling, is hard to handle, and is not generally accepted as a standard. The DIP evolution lies in surface mounting the device.

#### SMALL-OUTLINE INTEGRATED CIRCUITS

The small-outline integrated circuit (SOIC) is a descendant of the DIP. Sometimes called the "Swiss" outline integrated circuit in honor of its country of origin, this package solves many of the problems of the DIP. while retaining many of its advantages. The gull-wing lead rests on top of the printed circuit board rather than going through it. For most types, its leads are exactly half the length that the DIP's are, and it maintains the same basic rectangular package aspect ratio of the DIP. This, however, becomes a disadvantage in high-pin-count applications. For more than 28 pins. many designers prefer the square aspect of the plastic leaded chip carrier (PLCC) to the SOIC. The small package mass of the SOIC does not allow the same thermal dissipation that can be expected in a standard DIP, which becomes a minor problem as more chips are made in the generally lower power consuming CMOS process. Most importantly, the SOIC consumes only about 30% of the real estate consumed by the standard DIP. It is estimated that nearly 1.5 billion SOIC units will be shipped in 1986.

#### **CHIP CARRIERS**

Chip carriers have been around for several years in various forms, and are just now coming into widespread usage. Generally, the terminal spacing of chip carriers is 1.27 mm (50 mils), but several special types have 1.0 mm (40 mil) spacing for use by companies engaged in the pocket pager business. Some variations are available in 0.64 mm (25 mils) also. The ceramic versions of chip carriers have become very popular in military applications for the same reason the ceramic side-brazed DIP has: their mechanical ruggedness. Frequently, ceramic leadless chip carriers (LCCs) are soldered in: others use connectors, while still others have their own leads and are inserted as a leaded device. Due to the dissimilar coefficient of expansion of materials (package alumina and printed circuit board fiberglass) and the lack of pins on the leadless versions to provide flexibility or compliance, the ceramic leadless chip carriers should be soldered to a material that has the same thermal expansion characteristics as they have. This has become very popular



in military applications where weight and space are at a premium and, generally, cost is not the primary consideration.

The plastic leaded chip carrier (PLCC) has very guickly become the most popular of all the chip carriers. The PLCC represented about 61% of the chip carriers shipped in 1985 (approximately 400 million units). Although there is debate on the issue of board space consumption. the PLCC and SOIC consume about the same amount of board space in the 24- to 28-pin configurations. In lower pin count applications, the SOIC seems to be more spaceeffective; when over 24 pins or so. the PLCC seems to have the edge in most applications. In applications over 28 pins, the PLCC is the surfacemount package of choice. Its square aspect ratio allows many chip placements that the highly rectangular package of the SOIC does not. In addition, there are rectangular PLCCs to accommodate such rectangular die, such as memories.

### CHIP-ON-BOARD MOUNTING

The ultimate in low-cost chip mounting is achieved by the chip-onboard (COB) technology, in which no discrete package is actually employed. The die is soldered onto a copper pad on a printed circuit board. Bonding wires connect the die to smaller bonding pads around the die. The die and wires are then covered by a dollop of epoxy. This technique, while inexpensive, is not generally accepted in industrial or business equipment. It has been extensively employed in video game cartridges, and seems to work quite well there.

#### **PIN GRID ARRAY**

The pin grid array (PGA), or "bed of nails," has only been around for ten years, but had a usage of about 5 million in 1985, and its popularity is growing rapidly. This major package variation allows very high pin counts in relatively small spaces with excellent mechanical and thermal characteristics. The 149-pin VL82C389 Message Passing Coprocessor (MPC) for Multibus® II systems is a prime example of PGA high-density trends. The major disadvantage of the PGA is its high cost. Virtually all of the 5 million PGA units shipped in 1985 were ceramic. Plastic pin grid arrays are well along in development, and will provide reliable, inexpensive packaging for the many high-pin-count ASIC, memory, and other circuits coming into wide usage.

### FLATPACK

The flatpack holds less than 1% of the IC package market. True to its name, it is flat, small, and has flat leads usually in the same plane as the package body. It is generally harder to handle and test than the other package types, but provides a surface mounting alternative to the pin grid array in very-high-pin-count applications. It is usually surface mounted, "socketed," or suspended through a cut-out hole in the printed circuit board.

### SYSTEM CONSIDERATIONS

In the extremely competitive computer market that now exists, every repetitive cost, no matter how small, comes under close scrutiny. Drilling a hole in a printed circuit board costs about \$0.001, a fairly small amount until it is multiplied by the thousands of holes that frequently occur in each board. This becomes a significant consideration at the system level. Even though re-tooling costs are high, many companies are converting (some at least partially) to surface-mounting equipment. Surface mounting allows more chips in a much smaller area, but not all functions are yet available in surface-mount packages. Some companies have solved this problem by designing both through-the-board and surface-mount devices onto the same board. Others continue to use the older technology until they can re-tool for 100% surface mount.

Application-specific integrated circuits (ASICs) and their support devices are requiring packages with ever-increasing pin counts. The pin count domain diagram graphically depicts the typical domain of pin counts for five basic package types. While there is a good deal of overlap, chip carriers and pin grid arrays will become the package of choice in future systems containing devices of high pin count. Since the PGA device



Multibus is a registered trademark of Intel Corporation.



does not support surface-mount technology, chip carriers or flatpack technology will have to be implemented as pin counts exceed 170 using surface-mount systems.

### CONCLUSION

There will be no panacea package that will exclude the use of all others in the future. While there are several criteria for the system designer, Table 1 examines some of the characteristics of packages that will probably occupy the overwhelming majority of printed circuit boards in the future. Leadless chip carriers will be especially popular in military and harsh industrial applications. The DIP, with many billions already in use, will not disappear, but its percentage of market will decrease steadily. Pin grid arrays will remain and increase in popularity as very large devices become more popular and plastic PGAs become readily available. Surface mounting is definitely a wave of the future for many systems. SOIC packaging will increase rapidly for devices of 28 terminals and under, while the mid-range and higher terminal count devices will be housed in PLCCs or flatpacks.

### THERMAL CONSIDERATIONS

The devices in this data book have undergone thorough evaluation and characterization to ensure their operation over the specified temperature ranges. While safety margins are used for all parametric tests over the temperature range, the designer should not exceed the temperature limits, even for extremely short intervals. The following notes are presented to ensure a reliable, longlived system using VLSI's products:

- While few designs subject devices to extreme cold, such conditions may cause the devices to operate outside of their normal specified ranges. Therefore, the minimum operating temperature specification must be observed as well as the maximum operating temperature.
- The ambient temperature (TA) specification refers to the air on the surface of the device. The printed circuit board design should be open enough to permit free air flow around the devices.
- Avoid layouts that place NMOS, HMOS, or CMOS devices near such heat sources as power regulators and devices requiring heat sinks. If the design demands such proximity, ensure that the specified temperature range is not exceeded.
- Ensure that the power supply voltage is within the specified range. Both low and high voltages beyond the specified limits may cause device overheating.

| e Angele Ange | JEDEC Leadless Chip Carriers |              |              | DIP          |              |                     |                     |              |
|-----------------------------------------------------------------------------------------------------------------|------------------------------|--------------|--------------|--------------|--------------|---------------------|---------------------|--------------|
| Feature                                                                                                         | A                            | В            | С            | Ceramic      | Plastic      | SOIC                | PLCC                | PGA          |
| Uses Socket or Connector                                                                                        | Yes                          | Yes          | No           | Yes          | Yes          | No                  | Yes                 | Yes          |
| Directly Solderable                                                                                             | No                           | No           | Yes          | Yes          | Yes          | Yes                 | Yes                 | Yes          |
| Minimum Usual Terminal Count                                                                                    | 14                           | 14           | 14           | 6            | 6            | 8                   | 16                  | 40           |
| Maximum Usual Terminal Count                                                                                    | 156                          | 156          | 156          | 64           | 64           | 28                  | 156                 | 225          |
| Pin Spacing mm<br>(mils)                                                                                        | 1.27<br>(50)                 | 1.27<br>(50) | 1.27<br>(50) | 2.5<br>(100) | 2.5<br>(100) | 1.27/1.0<br>(50/40) | 1.27/1.0<br>(50/40) | 2.5<br>(100) |
| Relative Cost (1 = Most Costly)                                                                                 | 3                            | 4            | 5            | 2            | 8            | 7                   | 6                   | 1            |

### **TABLE 1. PACKAGE CHARACTERISTICS**



## PACKAGE OUTLINES

#### 18-PIN CERAMIC SIDE-BRAZED DUAL IN-LINE PACKAGE (DIP)





NOTES: UNLESS OTHERWISE SPECIFIED.

- NOTES: UNLESS OTHERWISE SPECIFIED. 1. ALL METRIC DIMENSIONS ARE IN PARENTHESES (). 2. TOLERANCE TO BE  $\pm$ .005 (0.127). 3. LEAD MATERIAL: ALLOY 42 (OR EQUIVALENT). 4. LEAD FINISH: GOLD PLATE OVER NICKEL.

### **18-PIN PLASTIC DUAL IN-LINE PACKAGE (DIP)**



- NOTES: UNLESS OTHERWISE SPECIFIED. 1. LEAD FINISH: MATTE TIN PLATE OR LEAD/TIN SOLDER. 2. LEAD MATERIAL: ALLOY 42 OR COPPER. 3. PACKAGE LENGTH DOES NOT INCLUDE END FLASH BURR, WHICH IS .010 (0.254) MAX. AT EACH END.
- MIAX: AI EACH END. TOLERANCE TO BE ±.005 (0.127) UNLESS OTHERWISE NOTED. METRIC DIMENSIONS ARE IN PARENTHESES ( ). PIN 1 INDEX MARK MAY VARY IN SIZE AND SHAPE. 4
- 5. 6.



### PACKAGE OUTLINES

20-PIN CERAMIC SIDE-BRAZED DUAL IN-LINE PACKAGE (DIP)



- NOTES: UNLESS OTHERWISE SPECIFIED. 1. ALL METRIC DIMENSIONS ARE IN PARENTHESES. 2. TOLERANCE TO BE  $\pm$  .005 (0.127). 3. LEAD MATENIAL: ALLOY 42 (OR EQUIVALENT). 4. LEAD FINISH: GOLD PLATE OVER NICKEL.

20-PIN PLASTIC DUAL IN-LINE PACKAGE (DIP)



NOTES: UNLESS OTHERWISE SPECIFIED. 1. LEAD FINISH: MATTE TIN PLATE OR LEAD/TIN SOLDER. 2. LEAD MATERIAL: ALLOY 42 OR COPPER. 3. PACKAGE LENGTH DOES NOT INCLUDE END FLASH BURR, WHICH IS .010 (0.254) MAX AT EACH END.

- TOLERANCE TO BE ± .005 (0.127).
   ALL METRIC DIMENSIONS ARE IN PARENTHESES.
   PIN 1 INDEX MARK MAY VARY IN SIZE AND SHAPE.



### PACKAGE OUTLINES

#### 24-PIN PLASTIC DUAL IN-LINE PACKAGE (DIP)



NOTES: UNLESS OTHERWISE SPECIFIED. 1. LEAD FINISH: MATTE TIN PLATE OR LEAD/TIN SOLDER. 2. LEAD MATERIAL: ALLOY 42 OR COPPER.

3. PACKAGE LENGTH DOES NOT INCLUDE END FLASH BURR, WHICH IS .010 (0.254) MAX AT EACH END. AT EACH END. 4. TOLERANCE TO BE ± .005 (0.127). 5. ALL METRIC DIMENSIONS ARE IN PARENTHESES. 6. PIN 1 INDEX MARK MAY VARY IN SIZE AND SHAPE.

#### 28-PIN CERAMIC SIDE-BRAZED DUAL IN-LINE PACKAGE (DIP)





### **PACKAGE OUTLINES**

28-PIN PLASTIC DUAL IN-LINE PACKAGE (DIP)



NOTES: UNLESS OTHERWISE SPECIFIED. 1. LEAD FINISH: MATTE TIN PLATE OR LEADTIN SOLDER. 2. LEAD MATTERIAL: ALLOY 42 OR COPPER. 3. PACKAGE LENGTH DOES NOT INCLUDE END FLASH BURR WHICH IS .010 (0.254) MAX. AT EACH END. 4. TOLERANCE TO BE  $\pm$  .005 (0.127) UNLESS OTHERWISE NOTED. 5. ALL METRIC DIMENSIONS ARE IN PARENTHESES.

6. PIN 1 INDEX MARK MAY VARY IN SIZE AND SHAPE.

**28-PIN PLASTIC LEADED CHIP CARRIER (PLCC)** 





### **PACKAGE OUTLINES**

40-PIN CERAMIC SIDE-BRAZED DUAL IN-LINE PACKAGE (DIP)



NOTES: UNLESS OTHERWISE SPECIFIED. 1. ALL METRIC DIMENSIONS ARE IN PARENTHESES. 2. TOLERANCE TO BE  $\pm$  .005 (0.127). 3. LEAD MATERIAL: ALLOY 42 (OR EQUIVALENT). 4. LEAD FINISH: GOLD PLATE OVER NICKEL.

#### 40-PIN PLASTIC DUAL IN-LINE PACKAGE (DIP)



NOTES: UNLESS OTHERWISE SPECIFIED. 1. LEAD FINISH: MATTE TIN PLATE OR LEAD/TIN SOLDER. 2. LEAD MATERIAL: ALLOY 42 OR COPPER.

LEAD MATERIAL: ALLOY 42 OR COPPER.
 PACKAGE LENGTH DOES NOT INCLUDE END FLASH BURR, WHICH IS .010 (0.254) MAX AT EACH END.
 TOLERANCE TO BE ± .005 (0.127).
 ALL METRIC DIMENSIONS ARE IN PARENTHESES.
 PIN 1 INDEX MARK MAY VARY IN SIZE AND SHAPE.



### PACKAGE OUTLINES

44-PIN PLASTIC LEADED CHIP CARRIER (PLCC)



- NOTES: UNLESS OTHERWISE SPECIFIED. 1. TOLLERANCE TO BE ± .005 (0.127). 2. LEADFRAME MATERIAL: COPPER. 3. LEAD FINISH: MATTE TIN PLATE OR SOLDER DIP. 4. SPACING TO BE MAINTAINED BETWEEN FORMED LEAD AND MOLDED PLASTIC ALONG FULL LENGTH OF LEAD. 5. MOLDED PLASTIC DIMENSION DOES NOT INCLUDE SIDE FLASH BURR, WHICH IS .010 (0.236) MAX ON FOUR SIDES. 6. ALL METRIC DIMENSIONS ARE IN PARENTHESES.

48-PIN CERAMIC SIDE-BRAZED DUAL IN-LINE PACKAGE (DIP)



NOTES: UNLESS OTHERWISE SPECIFIED.

NOTES: UNLESS OTHERWISE SPECIFIED.
 ALL METRIC DIMENSIONS ARE IN PARENTHESES.
 TOLERANCE TO BE ± .005 (0.127).
 LEAD MATERIAL: ALLOY 42 (OR EQUIVALENT).
 LEAD FINISH: GOLD PLATE OVER NICKEL.



### PACKAGE OUTLINES

#### 48-PIN PLASTIC DUAL IN-LINE PACKAGE (DIP)



NOTES: UNLESS OTHERWISE SPECIFIED.

NOTES: UNLESS UNLESS THE UN PLATE OR LEAD/TIN SOLDER. 1. LEAD MATERIAL: ALLOY 42 OR COPPER. 2. LEAD MATERIAL: ALLOY 42 OR COPPER. 3. PACKAGE LENGTH DOES NOT INCLUDE END FLASH BURR, WHICH IS .010 (0.254) MAX AT EACH END.

AI EACH END. TOLERANCE TO BE ± .005 (0.127) UNLESS OTHERWISE NOTED. METRIC DIMENSIONS ARE IN PARENTHESES. PIN 1 INDEX MARK MAY VARY IN SIZE AND SHAPE. 4

5. 6.

64-PIN CERAMIC SIDE-BRAZED DUAL IN-LINE PACKAGE (DIP)



NOTES: UNLESS OTHERWISE SPECIFIED. 1. ALL METRIC DIMENSIONS ARE IN PARENTHESES. 2. TOLERANCE TO BE  $\pm$  .005 (0:127). 3. LEAD MATERIAL: ALLOY 42 (OR EQUIVALENT). 4. LEAD FINISH: GOLD PLATE OVER NICKEL.



### PACKAGE OUTLINES

### 64-PIN PLASTIC DUAL IN-LINE PACKAGE (DIP)



A TOLERANCE TO BE ± .005 (0.127). 5. METRIC DIMENSIONS ARE IN PARENTHESES. 6. PIN 1 INDEX MARK MAY VARY IN SIZE AND SHAPE.

**68-PIN PLASTIC LEADED CHIP CARRIER (PLCC)** 



- SPACING TO BE INTRUMENTED OF WELLY FORMED LEND AND INSIDE LEND AND INSIDE LEND AND INSIDE LEND AND INSIDE AND INSIDIA AND INSIDE AND INSIDE AND INSIDIA AN 5.
- (0.254) MAX ON FOUR SIDES. ALL METRIC DIMENSIONS ARE IN PARENTHESES.
- 6.



### PACKAGE OUTLINES

84-PIN LEADLESS CHIP CARRIER (LCC)





### PACKAGE OUTLINES

84-PIN PLASTIC LEADED CHIP CARRIER (PLCC)



UNLESS OTHERWISE SPECIFIED; 1. ALL METRIC DIMENSIONS ARE IN PARENTHESES. METRIC DIMENSIONS ARE IN MILLIMETERS. 2. TOLERANCE TO BE ±.005 (0.127). 3. LEADFRAME MATERIAL: COPPER. 4. LEAD FINISH: MATTE TIN PLATE OR SOLDER DIP. 5. SPACING TO BE MAINTAINED BETWEEN FORMED LEAD AND MOLDED PLASTIC ALONG FULL LENGTH OF LEAD. 6. MOLDED PLASTIC DIMENSION DOES NOT INCLUDE SIDE FLASH BURR, WHICH IS .010 (0.254) MAX. ON FOUR SIDES.



### PACKAGE OUTLINES

#### 149-PIN CERAMIC PIN GRID ARRAY (PGA)



UNLESS OTHERWISE SPECIFIED: 1. ALL METRIC DIMENSIONS ARE IN PARENTHESES. METRIC DIMENSIONS ARE IN MILLIMETERS. 2. TOLERANCE TO BE ±.005 (0.127).

3.

TOLENANCE 10 BE ±.003 (0.127). MATERIAL: Al93. LEAD MATERIAL: KOVAR. LEAD FINISH IS GOLD PLATING (60 MICROINCHES MIN. THICKNESS) OVER NICKEL (100 MICROINCHES NOMINAL THICKNESS). 5.





| <br> | •••••••••••••••••••••••••••••••••••••• | <br>                                       | <br> |
|------|----------------------------------------|--------------------------------------------|------|
| <br> |                                        | <br>                                       | <br> |
| <br> |                                        | <br>                                       | <br> |
| <br> |                                        | <br>                                       | <br> |
|      |                                        | <br>                                       |      |
|      |                                        |                                            |      |
|      | <u></u>                                |                                            |      |
| <br> |                                        |                                            | <br> |
| <br> |                                        | <br>                                       | <br> |
| <br> |                                        | <br>                                       | <br> |
| <br> |                                        | <br>                                       | <br> |
| <br> | ······································ | <br>······································ | <br> |
| <br> |                                        | <br>                                       | <br> |
| <br> |                                        | <br>                                       |      |
| <br> |                                        | <br>                                       | <br> |
| <br> |                                        | <br>                                       |      |
| <br> |                                        | <br>                                       |      |
| <br> |                                        |                                            |      |
|      |                                        |                                            |      |
|      |                                        |                                            |      |
|      |                                        | <br>                                       |      |
| <br> |                                        |                                            | <br> |

SECTION 3 PROCESSORS AND COPROCESSORS

Application Specific Logic Products Division



# VL65C02+VL65NC02



## CMOS 8-BIT MICROPROCESSOR FAMILY

### FEATURES

- CMOS silicon-gate technology
- Low power (1.1 mA/MHz) •
- Software-compatible with the NMOS 6502
- . Single 5 V power supply required
- 8-bit parallel processing
- True indexing capability
- Programmable stack pointer .
- Interrupt capability
- Non-maskable interrupt
- 8-bit bidirectional data bus
- Addressable memory range of up to 64K bytes
- "Ready" input
- Direct memory access (DMA) capability
- Clock speeds up to 4 MHz
- Pipelined architecture
- On-chip clock options:
  - External single-input clock - On-board clock, single external crystal

### DESCRIPTION

The VL65C02 and VL65NC02 are 8-bit microprocessor devices produced using CMOS silicon-gate technology. These devices provide advanced system architecture for enhancements in system performance, speed, and value over their NMOS counterparts, the 65XX family of microprocessor devices. The VL65NC02 is the CMOS equivalent of the NMOS 6502, and contains some enhancements. The VL65C02 contains significant enhancements. Both CMOS types may exhibit different intermediate cycle information from that resident in the NMOS 6502. Intermediate cycle information is not specified, and should not be used.

Both the VL65C02 and VL65NC02 provide 64K bytes of addressable memory and an interrupt input, as well as options for on-chip oscillators and drivers. Both are bus-compatible and software-compatible with the 65XX CPU family.

### CLOCK GENERATOR

The clock generator develops all internal clock signals and (where applicable) external clock signals associated with the device. It is the clock generator that

drives the timing control unit and the external timing for slave mode operations.

#### TIMING CONTROL

The timing control unit keeps track of the instruction cycle being monitored. The unit is set to zero each time an instruction fetch is executed and is advanced at the beginning of each phase-one clock pulse for as many cycles as is required to complete the instruction. Each data transfer that takes place between the registers depends upon decoding the contents of both the instruction register and the timina control unit.

### **PROGRAM COUNTER**

The 16-bit program counter provides the addresses which step the microprocessor through sequential instructions in a program.

Each time the microprocessor fetches an instruction from program memory, the lower byte of the program counter (PCL) is placed on the low-order bits of the address bus and the higher byte of the program counter (PCH) is placed on the high-order 8 bits. The counter is incremented each time an instruction or data is fetched from program memory.

### **PIN DIAGRAM**



## ORDER INFORMATION

| Part<br>Number | Clock<br>Frequency                      | Package     |
|----------------|-----------------------------------------|-------------|
| VL65C02-01PC   |                                         | Plastic DIP |
| VL65C02-01CC   |                                         | Ceramic DIP |
| VL65NC02-01PC  | 1 MHZ                                   | Plastic DIP |
| VL65NC02-01CC  |                                         | Ceramic DIP |
| VL65C02-02PC   |                                         | Plastic DIP |
| VL65C02-02CC   | 0.1411-                                 | Ceramic DIP |
| VL65NC02-02PC  |                                         | Plastic DIP |
| VL65NC02-02CC  |                                         | Ceramic DIP |
| VL65C02-03PC   |                                         | Plastic DIP |
| VL65C02-03CC   | 0.1411-                                 | Ceramic DIP |
| VL65NC02-03PC  | 3 MHZ                                   | Plastic DIP |
| VL65NC02-03CC  |                                         | Ceramic DIP |
| VL65C02-04PC   | 1994 (A. 1994)<br>1997 - 1997 (A. 1997) | Plastic DIP |
| VL65C02-04CC   | 4 1414-                                 | Ceramic DIP |
| VL65NC02-04PC  |                                         | Plastic DIP |
| VL65NC02-04CC  |                                         | Ceramic DIP |
|                |                                         |             |

### Note:

Operating temperature range: 0°C to + 70°C
# VL65C02-VL65NC02

## BLOCK DIAGRAM



INTERNAL ARCHITECTURE

VL65C02•VL65NC02

## TABLE 1. HARDWARE ENHANCEMENTS

| The VL65C02/VL65NC02<br>microprocessor devices have been<br>designed with several bardware and | Feature                                | VL65C02<br>VL65NC02 |
|------------------------------------------------------------------------------------------------|----------------------------------------|---------------------|
| software enhancements over the NMOS                                                            | Pin-compatible with NMOS 6502          | x                   |
| compatability. In addition to the                                                              | 64K addressable bytes of memory        | x                   |
| increased speed and lower power                                                                | IRQ interrupt                          | x                   |
| technology, the VL65C02 and                                                                    | TTL-level single-phase clock input     | ×                   |
| VL65NC02 have the following                                                                    | RC time base clock input               | ×                   |
| characteristics:                                                                               | Crystal time base clock input          | ×                   |
| I wo new addressing modes                                                                      | Two-phase clock input*                 |                     |
| <ul> <li>Seven software/operational<br/>enhancements</li> </ul>                                | Two-phase output clock                 | x                   |
| Two hardware enhancements:                                                                     | SYNC and RDY signals                   | ×                   |
| VL65C02 only                                                                                   | Bus Enable (BE) signal*                |                     |
| - 12 new instructions, 68 total                                                                | Memory Lock (ML) output signal*        |                     |
| - 59 new opcodes, 210 total                                                                    | Direct Memory Access (DMA) capability* |                     |
| – 8 new instructions, 64 total                                                                 | NMI interrupt signal                   | x                   |
| – 27 new opcodes, 178 total                                                                    | *Available on other 650X types         |                     |

| SI | Gl | NA | L | D | E | 50 | CI | RI | P. | Т | 10 | ľ | ١S |  |
|----|----|----|---|---|---|----|----|----|----|---|----|---|----|--|
|    |    |    |   |   |   |    |    |    |    |   |    |   |    |  |

| Signal<br>Name                    | Pin<br>Number | Signal<br>Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Ø0 (IN),<br>Ø1 (OUT),<br>Ø2 (OUT) | 37,<br>3, 39  | Clock Signals–The VL65(N)C02 requires an external Ø0 clock. Ø0 is a TTL-level input that<br>is used to generate the internal clocks of the VL65(N)C02. Two full-level output clocks are<br>generated by the VL65(N)C02. The Ø2 clock is in phase with Ø0. The Ø1 clock output is<br>180° out of phase with Ø0. When Ø0 is stopped, the CPU is in the standby mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| ĪRQ                               | 4             | Interrupt Request–This TTL-compatible input requests that an interrupt sequence begin within the microprocessor. The IRQ is sampled during Ø2 operation; if the interrupt flag in the processor status register is zero, the current instruction is completed and the interrupt sequence begins during Ø1. The program counter and processor status register are stored in the stack. The microprocessor then sets the interrupt mask flag HIGH so that no further IRQs may occur. At the end of this cycle, the program counter low byte is loaded from address FFFE, and program counter high byte from location FFFF, thus transferring program control to the memory vector located at these addresses. The RDY signal must be in the HIGH state for any interrupt to be recognized. A 3 K-ohm external resistor should be used for proper wire-OR operation. |
| NMI .                             | 6             | Non-Maskable Interrupt–A negative-going edge on this input requests that a non-<br>maskable interrupt sequence be generated within the microprocessor. The NMI is<br>sampled during Ø2; the current instruction is completed and the interrupt sequence<br>begins during Ø1. The program counter is loaded with the interrupt vector from locations<br>FFFA (low byte) and FFFB (high byte), thereby transferring program control to the non-<br>maskable interrupt routine.                                                                                                                                                                                                                                                                                                                                                                                      |
|                                   |               | Note - Since this interrupt is non-maskable, another NMI can occur before the first is finished. Care should be taken when using NMI to avoid this.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

# VL65C02-VL65NC02

## SIGNAL DESCRIPTIONS (CONTINUED)

| Signal<br>Name | Pin<br>Number | Signal<br>Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RDY            | 2             | Ready –This input allows the user to single-cycle the microprocessor on all cycles,<br>including write cycles. A negative transition to the LOW state, during or coincident with<br>Ø1, halts the microprocessor with the output address lines reflecting the current address<br>being fetched. This condition remains through a subsequent Ø2 in which the ready signal<br>is LOW. This feature allows micrprocessor interfacing with low-speed memory as well as<br>direct memory access (DMA).                                   |
| R∕₩            | 34            | Read/Write –This signal is normally in the HIGH state, indicating that the microprocessor<br>is reading data from memory or I/O bus. In the LOW state, the data bus has valid data<br>from the microprocessor to be stored at the addressed memory location.                                                                                                                                                                                                                                                                        |
| SO             | 38            | Set Overflow – A negative transition on this line sets the overflow bit (V) in the processor<br>status register. The signal is sampled prior to the leading edge of Ø2 by the processor<br>control time (tRWS).                                                                                                                                                                                                                                                                                                                     |
| RES            | 40            | Reset –This input resets the microprocessor. Reset must be held LOW for at least two<br>clock cycles after VCC reaches operating voltage from a power-down. A positive<br>transition on this pin causes an initialization sequence to begin. Likewise, after the<br>system has been operating, a LOW on this line of at least two cycles ceases<br>microprocessing activity, followed by initialization after the positive edge on RES.                                                                                             |
|                |               | When a positive edge is detected, there is an initialization sequence lasting six clock cycles. Then, the interrupt mask flag is set, the decimal mode is cleared, and the program counter is loaded with the restart vector from locations FFFC (low byte) and FFFD (high byte). This is the start location for program control. This input should be HIGH in normal operation.                                                                                                                                                    |
| SYNC           | 7             | Synchronize –This output line identifies those cycles during which the microprocessor is fetching the instruction operation code (op code). The SYNC line goes high during Ø1 of an opcode fetch and stays HIGH for the remainder of that cycle. If the RDY line is pulled LOW during the Ø1 clock pulse in which SYNC went HIGH, the processor stops in its current state and remains in the state until the RDY line goes HIGH. In this manner, the SYNC signal can be used to control RDY to cause single instruction execution. |
| A0-A15         | 9-25          | Address Bus–A0-A15 forms a 16-bit address bus for memory and I/O exchanges on the<br>data bus. The output of each address line is TTL-compatible, capable of driving one<br>standard TTL load and 130 pF.                                                                                                                                                                                                                                                                                                                           |
| D0-D7          | 33-26         | Data Bus–The data lines constitute an 8-bit bidirectional data bus used for data<br>exchanges to and from the device and peripherals. The outputs are three-state buffers<br>capable of driving one TTL load and 130 pF.                                                                                                                                                                                                                                                                                                            |
| VCC            | 8             | +5 V $\pm$ 5% power supply                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| VSS            | 1,21          | Digital ground                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

## TABLE 2. VL65C02/VL65NC02 NO OPERATION (NOP) TIMING FOR UNDEFINED OPCODES

|                               | Op code   | Number of Bytes Expected (Total, Including Op code) | Number of<br>Cycles |
|-------------------------------|-----------|-----------------------------------------------------|---------------------|
|                               | X2        | 2                                                   | 2                   |
|                               | ХЗ        |                                                     | 1                   |
|                               | <b>X7</b> | 1                                                   | 1*                  |
|                               | ХВ        |                                                     | 1                   |
|                               | XF        |                                                     | 1*                  |
|                               | 44        | 2                                                   | 3                   |
|                               | 54        | 2                                                   | 4                   |
|                               | D4        | 2                                                   | 4                   |
| Notes:                        | F4        | 2                                                   | 4                   |
| "X" – Don't care              | 5C        | 3                                                   | 8                   |
| * – Applies to VL65NC02 only  | DC        | 3                                                   | 4                   |
| (valid operation for VL65C02) | FC        | 3                                                   | 4                   |

VL65C02•VL65NC02

## INSTRUCTION AND REGISTER DECODE

Instructions fetched from memory are gated onto the internal data bus. These instructions are latched into the instruction register, then decoded, along with timing and interrupt signals, to generate control signals for the various registers.

### ARITHMETIC/LOGIC UNIT

All arithmetic and logic operations take place in the ALU, including incrementing and decrementing internal registers (except the program counter). The ALU has no internal memory and is used only to perform logical and transient numerical operations.

#### ACCUMULATOR

The accumulator is a general-purpose 8bit register that stores the results of most arithmetic and logic operations. In addition, the accumulator usually contains one of the two data words used in these operations.

## INDEX REGISTER

There are two 8-bit index registers (X and Y) that may be used to count program steps or to provide an index value to be used in generating an effective address.

When executing an instruction that

specifies indexed addressing, the CPU fetches the op code and the base address, and modifies the address by adding the index register to it prior to performing the desired operation. Preor post-indexing of indirect addresses is possible (see addressing modes).

### STACK POINTER

The stack pointer is an 8-bit register used to control the addressing of the variable-length stack on page one. The stack pointer is automatically incremented and decremented under control of the microprocessor to perform stack manipulations under direction of <u>either</u> the program or interrupts (NMI and IRQ). The stack allows simple implementation of nested sub-routines and mulitple-level interrupts. The stack pointer should be initialized before any interrupts or stack operations occur.

#### PROCESSOR STATUS REGISTER

The 8-bit processor status register contains seven status flags. Some of the flags are controlled by the program, others may be controlled by the program and the CPU. The VL65(N)C02 instruction set contains a number of conditional branch instructions that are designed to allow testing of these flags.

## HARDWARE ENHANCEMENTS

The VL65C02 family of CPU devices has incorporated hardware enhancements over its NMOS counterpart, the 6502. These hardware enhancements are:

- The NMOS device would ignore the assertion of a Ready (RDY) during a write operation. The CMOS family stops the processor during Ø2 clock if RDY is asserted during a write operation.
- On the NMOS device, unused inputonly pins (IRQ, NMI, RDY, RES, and SO) must be connected to a low impedance signal to avoid noise problems. These unused pins on the CMOS devices are internally connected by a high-impedance to Vcc (approximately 250 K-ohms).

#### OPERATIONAL ENHANCEMENTS Tables 1 and 3 list the operational

enhancements that have been added to the CMOS family of CPU devices and compares the results with its NMOS 6502 counterpart.

| TΑ | BLE | 3. | SOFTWARE | <b>ENHANCEMENTS</b> |
|----|-----|----|----------|---------------------|
|----|-----|----|----------|---------------------|

| Function                                            | VL65C02 Microprocessor                                         | NMOS 6502 Microprocessor                             |
|-----------------------------------------------------|----------------------------------------------------------------|------------------------------------------------------|
| Indexed addressing across page boundary             | Extra read of last instruction byte                            | Extra read of invalid address                        |
| Execution of invalid opcodes                        | All are NOPs (reserved for future use)                         | Some terminate only by reset; results are undefined  |
| Jump indirect, operand = XXFF                       | Page address increments and adds<br>one additional cycle       | Page address does not<br>increment                   |
| Read/modify/write instructions at effective address | Two read and one write cycles                                  | One read and two write cycles                        |
| Decimal flag                                        | Initialized to binary mode (D=0)<br>after reset and interrupts | Indeterminate after reset                            |
| Flags after decimal operation                       | Valid flag adds one additional cycle                           | Invalid N, V and Z flags                             |
| Interrupt after fetch of BRK instruction            | BRK is executed, then interrupt is executed                    | Interrupt vector is loaded;<br>BRK vector is ignored |



## ADDRESSING MODES

The VL65(N)C02 CPU family has 15 addressing modes (two more than the NMOS-equivalent family). In the following discussion of these addressing modes, a bracketed expression follows the title of the mode. This expression is the term used in the Instruction Set Opcode Matrix, Table 8, to make it easier to identify the actual addressing mode used by the instruction.

#### ACCUMULATOR ADDRESSING

[Accum]- This form of addressing isrepresented by a one-byte instruction, implying an operation on the accumulator.

#### IMMEDIATE ADDRESSING

[IMM] - In immediate addressing, the second byte of the instruction contains the operand, with no further memory addressing required.

#### ABSOLUTE ADDRESSING

[Absolute] - In absolute addressing, the second byte of the instruction specifies the eight low-order bits of the effective address, while the third byte specifies the eight high-order bits. Thus, the absolute addressing mode allows access to the entire 64K bytes of addressable memory.

## ZERO PAGE ADDRESSING

[ZP] - The zero page instructions allow for shorter code and execution times by fetching only the second byte of the instruction and assuming a zero high address byte. Careful use of the zero page can result in a significant increase in code efficiency.

#### INDEXED ZERO PAGED ADDRESSING

[ZP, X, or Y] - (X, Y Indexing) - This form of addressing is used with the index register and is referred to as "zero page, X" or "zeropage, Y". The effective address is calculated by adding the second byte to the contents of the index register. Since this is a form of "zero page" addressing, the content of the second byte references a location in page zero. Additionally, due to the "zero page" addressing nature of this mode, no carry is added to the high-order eight bits of memory and crossing of page boundaries does not occur.

## INDEXED ABSOLUTE ADDRESSING

[ABS, X, or Y] - (X, Y Indexing) - This form of addressing is used in conjunction with X and Y index register and is referred to as "absolute, X" and "absolute, Y". The effective address is formed by adding the contents of X or Y to the address contained in the second and third bytes of the instruction. This mode allows the index register to contain the index or count value and the instruction to contain the base address. This type of indexing allows any location referencing and the index to modify multiple fields, resulting in reduced coding and execution time.

#### INDEXED ABSOLUTE INDIRECT

[(IND), X] - (JMP (IND), X) - The contents of the second and third instruction bytes are added to the X register. The 16-bit result is a memory address containing the effective address.

#### IMPLIED ADDRESSING

[Implied] - In the implied addressing mode, the address containing the operand is implicity stated in the operation code of the instruction.

## RELATIVE ADDRESSING

[Relative] - Relative addressing is used only with branch instructions and establishes a destination for the conditional branch.

The second byte of the instruction becomes the operand, which is an "offset" added to the contents of the lower eight bits of the program counter when the counter is set at the next instruction. The 8-bit offset provides a branching range of -128 to +127 bytes from the next instruction.

## INDEXED INDIRECT ADDRESSING

[(IND, X)] - In indexed indirect addressing, referred to as indirect, X, the second byte of the instruction is added to the contents of the X index register, discarding the carry. The result of this addition points to a memory location on page zero whose contents are the low-order eight bits of the effective address. The next memory location in page zero contains the highorder eight bits of the effective address. Both memory locations specifying the high-and low-order bytes of the effective address must be in page zero.

#### INDIRECT INDEXED ADDRESSING

[(IND), Y] - In indirect indexed addressing, referred to as indirect, Y, the second byte of the instruction points to a memory location in page zero. The contents of this memory location are added to the contents of the Y index register, the result being the low-order eight bits of the effective address. The carry from this addition is added to the contents of the next page zero memory location, the result being the high-order eight bits of the effective address.

## **ABSOLUTE INDIRECT**

[Indirect] - The second byte of the instruction contains the low-order eight bits of a memory location. The highorder eight bits of that memory location are contained in the third byte of the instruction. The contents of the fully specified memory location are the loworder byte of the effective address. The next memory location contains the highorder byte of the effective address, which is loaded into the 16 bits of the program counter, (JMP (IND) only).

### INDIRECT

[(IND)] - The second byte of the instruction contains a zero page address serving as the indirect pointer. This is not available on the NMOS 6500 family.

## TABLE 4. INSTRUCTION SET SUMMARY

## Notes:

- 1. Add 1 to "n" if page boundary is crossed, except STA and STZ.
- Add 1 to "n" if branch occurs to same page. Add 2 to "n" if branch occurs to different page.
   Add 1 to "n" if decimal mode.
- 4. Accumulator address is included in Implied address.
- 5. "N" and "V" flags are unchanged in immediate mode.
- 6. "Z" flag indicates AAM result (same as BIT instruction).

- X Index X e. Y Index Y
  - A Accumulator
  - M Memory per effective address
  - Ms Memory per stack pointer
- Subtract # ∧ And M

+ Add

V Or

- n No. Cycles # No. Bytes Me Memory Bit #6
- M7 Memory Bit #7
- ¥ Exclusive or

3–8

VL65C02•VL65NC02

## TABLE 4. INSTRUCTION SET SUMMARY (CONTINUED)

|       |                                | IN       | лм       | E-        | AE | SO-                    | Z        | ERC | 2        | (4             | )     |              |              |   | ()  | 1)  | Τ.          |              |     |     | (1)          |          | (  | 1)      | RI  | ELA-                  | IN | IDI-             |              |               |        | P  | RO       | CE  | ssc        | R   |            |
|-------|--------------------------------|----------|----------|-----------|----|------------------------|----------|-----|----------|----------------|-------|--------------|--------------|---|-----|-----|-------------|--------------|-----|-----|--------------|----------|----|---------|-----|-----------------------|----|------------------|--------------|---------------|--------|----|----------|-----|------------|-----|------------|
| MNE-  |                                |          | T        | Ē         |    |                        | P/       |     | - 11     |                | T     | (11)         | ΓÎ           | 1 |     | Ť   | +           | T            | Ĥ   |     | 35,7         | 4        |    | T IS, Y | 111 | $\frac{E(2)}{\Gamma}$ |    |                  | ÷            | T             | Ť      | 7  | 6 -      | 4 3 | 2          | 1 0 | MNE-       |
| MONIC | OPERATION                      | OP       | <u>'</u> | #         | OP | n #                    | OP       | n   | ŧ (      | DP             | n #   | OP           | n            | # | ОР  | n # | 0           | Pr           | #   | OP  | nł           | #        | QР | n #     | OP  | n #                   | OP | ni               | # C          | )P n          | #      | N  | VE       | 3 D | )   Z      | zc  | MONIC      |
| ADC   | $A + M + C \rightarrow A  (3)$ | 69       | 2        | 2         | 6D | 43                     | 65       | 3   | 2        |                |       | 61           | 6            | 2 | 71  | 5 2 | 2 7         | 75           | 2   | 7D  | 4            | 3        | 79 | 4 3     |     |                       | 72 | 5                | 2            |               |        | N  | ۷ •      | • • | • 2        | c C | ADC        |
| AND   | C - 7 0 -0                     | 28       | "        | 2         | 0E | 63                     | 06       | 5   | 2        | OA             | 2 1   | 2            | ľ            | 4 | 3   | ຳ   |             | 16 6         | 5 2 | 1E  | 6            | 3        | 39 | 43      | 1   |                       | 32 | <sup>5</sup>     | 2            |               |        | N  | •••      | ••• | • 2        | c   | AND        |
| всс   | BRANCH IF C=0 (2)              |          |          |           |    |                        |          |     |          |                |       |              |              |   |     |     |             |              |     |     |              |          |    |         | 90  | 22                    |    |                  |              |               |        | •  | •        |     | •••        | •   | BCC        |
| BCS   | BRANCH IF C=1 (2)              | ļ        | +        | $\square$ |    |                        |          |     | +        | _              |       | <b> </b>     | $\square$    | - |     | +   | +           | +            | +   |     |              | _        |    |         | BO  | 22                    |    | $\square$        | $\downarrow$ |               | ╞      | ŀ  | • •      | • • | ••         | •   | BCS        |
| BEQ   | BRANCH IF Z=1 (2)              | 80       |          |           | 20 | 43                     | 24       |     |          |                |       |              |              |   |     |     |             | 1            | 1,  | 20  |              | <u>_</u> |    |         | FO  | 22                    |    |                  |              |               |        |    | • •      | •   | •••        |     | BEQ        |
| ВМІ   | BRANCH IF N=1 (2)              |          | 1        | 1         | 20 | ٦°                     | 27       |     | -        |                |       |              |              |   |     |     | 1           | <u>-</u>     | 1   | 1.0 |              | 3        |    |         | 30  | 22                    |    |                  |              |               |        |    | • (      |     |            |     | BMI        |
| BNE   | BRANCH IF Z=0 (2)              |          |          |           |    |                        |          |     |          |                |       | l            |              |   |     |     |             |              |     |     |              |          |    |         | DO  | 22                    |    |                  |              |               |        | •  | • •      | • • | ••         | •   | BNE        |
| BPL   | BRANCH IF N=0 (2)              |          | +        | $\square$ |    | $\left  \cdot \right $ |          |     | -        |                |       | _            |              | + | _   | -   | +           | +            | +   |     | $\square$    | _        |    | _       | 10  | 22                    |    | 14               | +            | _             | +      | ŀ  | <u>.</u> |     | •••        | •   | BPL        |
| BRK   | BREAK                          |          |          |           |    |                        |          |     |          | 00             | 7 1   |              |              |   |     |     |             |              |     |     |              |          |    |         | 80  | 22                    |    |                  |              |               |        |    | • 1      | 10  | . 1 .      |     | BRA        |
| BVC   | BRANCH IF V=0 (2)              |          |          |           |    |                        |          |     |          |                | 1     |              |              |   |     |     |             |              |     |     |              |          |    |         | 50  | 22                    |    |                  |              |               |        |    | • •      |     | • •        | •   | BVC        |
| BVS   | BRANCH IF V=1 (2)              |          |          |           |    |                        |          |     |          |                |       |              |              |   |     |     |             |              |     |     |              |          |    |         | 70  | 22                    |    |                  |              |               |        | ŀ  | • •      | •   | ••         | :   | BVS        |
|       |                                |          |          |           |    |                        |          |     |          | 18             | 211   |              |              |   |     |     |             |              |     |     |              |          |    |         |     |                       |    |                  |              |               |        | 1: |          |     | •••        | 0   | CLC        |
| CLI   | 0-1                            |          | +        | Ħ         |    | +                      | 1        | H   | ť        | 58             | 21    | 1            | H            | + | -   | +   | +           | +            | +   |     | H            |          |    |         | 1   |                       | 1  |                  | +            | +             | +      | 1. | • •      |     | 0.         |     | CLI        |
| CLV   | 0 - V                          |          |          |           |    |                        |          |     |          | в8             | 2 1   |              |              |   |     |     |             |              |     |     |              |          |    |         |     |                       |    | 11               |              |               |        |    | 0.       | •   | ••         | •   | CLV        |
| CMP   | A-M                            | C9       | 2        | 2         | CD | 43                     | C5       | 3   | 2        |                |       | C1           | 6            | 2 | D1  | 5 2 | 2 .         | 05 4         | 12  | DD  | 4            | 3        | D9 | 4 3     |     |                       | D2 | 5                | 2            |               | 1      | N  | • •      | •   | • Z        | c   | CMP        |
| CPX   | Y-M                            | EU<br>CO |          | 2         | EC | 43                     |          | 3   | 2        |                |       |              |              |   |     |     |             |              |     |     |              |          |    |         |     |                       |    |                  |              |               |        |    | •••      | ••• | • Z        |     | CPX        |
| DEC   | DECREMENT                      |          | 1        | -         | CE | 63                     | C6       | 5   | 2        | за             | 2 1   | -            |              | + | -   | +   |             | 06 6         | 5 2 | DE  | 6            | 3        |    |         |     | t t                   | 1  | Ħ                | +            | +             | +      | N  | • •      | •   | • Z        |     | DEC        |
| DEX   | X-1 → X                        |          |          |           |    |                        |          |     | 0        | CA             | 2 1   |              |              |   |     |     |             |              |     |     |              |          |    |         |     |                       |    |                  |              |               |        | N  | • •      | •   | • Z        | •   | DEX        |
| DEY   | $Y-1 \rightarrow Y$            | 40       |          |           |    |                        | 45       |     |          | 88             | 2     |              |              |   |     | _   |             |              |     |     |              |          |    |         |     |                       |    |                  |              |               |        | N  | • •      | •   | • Z        | •   | DEY        |
|       |                                | 49       | 12       | 2         | 4D | 43                     | 45<br>F6 | 5   |          | 14             | 21    | 41           | Ь            | 2 | 51  | 5 2 | 2  5<br>  F | 55 4<br>76 6 | 2   | 5D  | 4            | 3        | 59 | 4 3     |     |                       | 52 | 5                | 2            |               |        |    | •••      | ••• | • 2        |     | EOR        |
| INX   | $X + 1 \rightarrow X$          |          | 1        |           |    | 1 T                    |          |     |          | E8             | 2 1   |              | H            |   | -   | +   | Ť           | -            | 1   |     |              | Ť        |    |         |     | ††                    |    | Ħ                | +            | +             | $^{+}$ | N  | • •      |     | • Z        | •   | INX        |
| INY   | $Y + 1 \rightarrow Y$          |          |          |           |    |                        |          |     |          | C8             | 2 1   |              |              |   |     |     |             |              |     |     |              |          |    |         |     |                       |    |                  |              |               |        | N  | • •      | •   | • Z        | :•  | INY        |
| JMP   | JUMP TO NEW LOC                | ł –      |          |           | 4C | 33                     |          |     |          |                |       | 70           | 6            | 3 |     |     |             |              |     |     |              |          |    |         |     |                       | 6C | 6                | 3            |               |        | •  | •••      | •   | •••        | •   | JMP        |
| LDA   | M - A                          | A9       | 2        | 2         | AD | 43                     | A5       | 3   | 2        |                |       | A1           | 6            | 2 | в1  | 5 2 | 2 8         | 35 4         | 2   | BD  | 4            | 3        | в9 | 4 3     |     |                       | B2 | 5                | 2            |               |        | N  |          |     | • 2        |     | LDA        |
| LDX   | M → X                          | A2       | 2        | 2         | AE | 4 3                    | A6       | 3   | 2        | _              | T     | -            |              | 1 |     |     |             |              |     |     |              |          | BE | 4 3     |     | $\square$             | 1  | T                | E            | 36 4          | 1 2    | N  | • •      | •   | • Z        | •   | LDX        |
| LDY   | M - Y                          | A0       | 2        | 2         | AC | 43                     | A4       | 3   | 2        |                |       |              |              |   |     |     | В           | 34 4         | 2   | вс  | 4            | 3        |    |         |     |                       |    |                  |              |               |        | N  | •••      | •   | • Z        | •   | LDY        |
|       |                                |          |          |           | 4E | 63                     | 46       | 5   | 2        | 4A             | 211   | l            |              |   |     |     | 5           | 56 6         | 2   | 5E  | 6            | 3        |    |         |     |                       |    |                  |              |               |        | 0  | : :      | : : | • Z        | C   | LSR        |
| ORA   | AVM - A                        | 09       | 2        | 2         | 0D | 4 3                    | 05       | 3   | 2        | -^             | "     | 01           | 6            | 2 | 11  | 5 2 | 2 1         | 15 4         | 2   | 1D  | 4            | 3        | 19 | 4 3     |     |                       | 12 | 5                | 2            |               |        | N  | • •      |     | • Z        |     | ORA        |
| PHA   | A⊸Ms S-1⊸S                     |          |          |           |    |                        |          |     |          | 48             | 3 1   |              |              | T |     |     |             | T            |     |     |              | 1        |    |         |     |                       |    | Ħ                |              |               |        | •  | • •      | •   | • •        | •   | PHA        |
| PHP   | P→Ms S-1→S                     |          |          |           |    |                        |          |     |          | 80             | 3 1   |              |              |   |     |     |             |              |     |     |              |          |    |         |     |                       |    |                  |              |               |        | ·  | •••      | •   | ••         | •   | PHP        |
| PHX   | X→Ms S-1→S<br>Y→Ms S-1→S       |          |          |           |    |                        |          |     | Ľ        |                | 311   |              |              |   |     |     |             |              |     |     |              |          |    |         |     |                       | 1  |                  |              |               |        | :  | •••      | ••• | •••        | :   | РНХ<br>РНУ |
| PLA   | S+1→S Ms→A                     |          |          |           |    |                        |          |     |          | 68             | 4 1   |              |              |   |     |     |             |              |     |     |              |          |    |         |     |                       |    |                  |              |               |        | N  |          | •   | • Z        | •   | PLA        |
| PLP   | S+1→S Ms→P                     |          | Г        |           |    |                        |          |     | Т        | 28             | 4 1   |              | Π            | Τ |     | Τ   | Τ           | Τ            |     |     | Π            |          |    |         |     | Π                     |    | Π                |              |               | Τ      | N  | V 1      | I D | IZ         | c c | PLP        |
|       | S+1→S Ms→X                     |          |          |           |    |                        |          |     | 1        | FA             | 4 1   |              |              |   |     |     |             |              |     |     |              |          |    |         |     |                       |    |                  |              |               |        | N  | • •      | • • | • Z        | •   | PLX        |
| ROL   | - 7 0 -C-                      |          |          |           | 2E | 63                     | 26       | 5   |          | 2A             | 211   |              |              |   |     |     | 13          | 36 6         | 2   | 3E  | 6            | 3        | 1  |         |     |                       |    |                  |              |               |        | N  |          |     | • 2        | ċ   | ROL        |
| ROR   | -C- 7 0                        |          |          |           | 6E | 63                     | 66       | 5 2 | 2 6      | 6A             | 2 1   |              | Ħ            | T |     | 1   | 7           | 66           | 2   | 7E  | 6            | 3        |    |         |     |                       | 1  | Ħ                | T            |               |        | N  | • •      | •   | • Z        | C   | ROR        |
| RTI   | RTRN INT                       |          |          |           |    |                        |          |     |          | 40             | 6 1   |              |              |   |     |     |             |              |     |     |              |          |    |         |     |                       |    |                  |              |               |        | N  | V 1      | D   | ΙZ         | c   | RTI        |
| SBC   | A-M-C→A (3)                    | = a      |          | 5         | ED | 12                     | 5        | 2   | , '      | 60             | 6   1 | E1           | 6            | , | =1  | 6   | .   _       | 5            |     | =   |              |          | =  |         |     |                       | E2 |                  |              |               |        |    | •••      | •   | ••         |     | RTS        |
| SEC   | 1-C                            |          | ľ        | ſ         |    | J                      | 15       | ľ   | -        | 38             | 2 1   | <sup>ב</sup> | ľ            | - | ' ' | " 2 | Ϊ           | 14           | 1   | '   | ľ            | ٦        | 19 | 1       |     |                       | 12 | '                | -            |               |        |    | •••      |     | • •        | 1   | SEC        |
| SED   | 1 - D                          | Γ        | Γ        | Π         |    |                        |          |     | T        | F8             | 2 1   |              | Π            | T |     | 1   | T           | 1            |     |     |              | 1        |    | T       | 1   | $\square$             | 1  | $ \uparrow$      | 1            | T             | T      | •  | • •      | 1   | •••        | •   | SED        |
| SEI   | 1-1                            |          |          |           |    |                        | 1        |     |          | 78             | 2 1   | 0.           |              |   |     |     |             |              |     |     |              |          | _  | -       |     |                       |    |                  |              |               |        | •  | •••      | •   | 1.•        | •   | SEI        |
| STP   | STOP (1 → Ø2)                  |          |          |           | 80 | 43                     | 85       | 3   | ÷ _      | зв             | 3 1   | 81           | ۴            | 2 | 91  | 6   | 9           | 10 4         | 2   | 90  | 15           | 3        | 99 | 5 3     |     |                       | 92 | 5                | 4            |               |        | :  | •••      |     |            |     | STA        |
| STX   | X → M                          |          |          |           | 8E | 4 3                    | 86       | 3   | 2        |                | 1     |              |              |   |     |     |             |              |     | l i |              |          |    |         |     |                       | 1  |                  | 1            | <b>96</b>   4 | 12     | •  | • •      | •   | • •        | •   | STX        |
| STY   | $Y \rightarrow M$              | -        | +-       | Η         | 8C | 43                     | 84       | 3 2 | 2        | -+             | +     |              | $\square$    | + |     | +   | 9           | 4 4          | 2   |     | 1            |          |    | +       | ╂   | $\square$             |    | $\left  \right $ | -            | +             | +      | ŀ  | •••      |     | <u>.</u>   | •   | STY        |
| TAX   | UU → M<br>A → X                |          |          |           | яC | 4 3                    | 64       | 3   | <u>،</u> | ام             | 21    |              |              |   |     |     | 17          | 44           | 2   | 9E  | 5            | 3        |    |         |     |                       |    |                  |              |               |        | Ň  | •••      | •   | . 7        |     | STZ<br>TAY |
| TAY   | A → Y                          |          | 1        |           |    |                        |          |     | 17       | 48             | 2 1   |              |              |   |     |     |             |              |     |     |              |          |    |         |     |                       |    |                  |              |               |        | N  | • •      | •   | ٠z         | •   | TAY        |
| TRB   | Ā∧м → м (6)                    |          |          |           | 1C | 63                     | 14       | 5 2 | 2        |                |       |              |              |   | - [ |     |             |              |     |     |              |          |    |         |     |                       | l  |                  |              |               |        | ·  | •••      | •   | • Z        | •   | TRB        |
| TSB   | AVM → M (b)                    | ┝        | +        | Н         | 0C | 63                     | 04       | 52  | 2        | <del>,</del> , | +     |              | $\mathbb{H}$ | + | -+  | +   | +           | +            |     |     | $\mathbb{H}$ | +        |    | +       | +   | ⊢                     |    | $\left  \right $ | +            | +             | +-     | •  | •••      |     | • <u>z</u> | •   | TSB        |
| TXA   | X - A                          |          |          |           |    |                        |          |     | E S      |                | 2 1   |              |              |   |     |     |             |              |     |     |              |          |    |         |     |                       |    |                  |              |               |        | N  | •••      |     | • 2        |     | TXA        |
| TXS   | X → S                          |          |          |           |    |                        |          |     |          | A              | 2 1   |              |              |   |     |     | 1           | 1            |     |     |              |          |    |         |     |                       |    |                  |              |               |        | •  | • •      | •   | ••         | •   | TXS        |
| TYA   | Y → A                          |          |          |           |    |                        |          |     | 1        | 98             | 2 1   |              |              |   | - 1 |     |             |              |     |     |              |          |    |         | 1   |                       |    |                  |              |               | Ł      | Ν  | •••      | •   | • Z        | •   | TYA        |
| L WAI |                                | 1        | L        | L         |    |                        |          |     | -10      | ъяl,           | 311   | 1            | 1            | 1 | - 1 |     | 1           | 1            | 1   |     | 11           | 1        | I  |         | 1   |                       | 1  |                  | 1            |               | 1      | ۰. | • •      | •   | • •        | •   | WAI        |



## **INSTRUCTION SET**

Table 5 lists the instruction set for the CMOS CPU family in alphabetic order according to mnemonic. Table 6 lists the hexadecimal codes for each of the instructions that are new to the CMOS family and were not available in the NMOS 6502 device family. Table 7 lists those instructions that were available on the NMOS family, but have been assigned new addressing modes in the CMOS CPU family.

## TABLE 5. INSTRUCTION SET LISTING (ALPHABETIC)

| Mnem         | onic | Function                                   | Mnemonic              | Function                                     |
|--------------|------|--------------------------------------------|-----------------------|----------------------------------------------|
| (2)          | ADC  | Add Memory to Accumulator with Carry       | NOP                   | No Operation                                 |
| (2)          | AND  | Shift Left One Bit (Memory or Accumulator) | (2) ORA               | OR Memory with Accumulator                   |
| (1)(3)       | BBR  | Branch on Bit Reset                        | РНА                   | Push Accumulator on Stack                    |
| (1)(3)       | BBS  | Branch on Bit Set                          | PHP                   | Push Processor Status on Stack               |
|              | BCC  | Branch on Carry Clear                      | (1) PHX               | Push X Register on Stack                     |
|              | BCS  | Branch on Carry Set                        | (1) PHY               | Push Y Register on Stack                     |
|              | BEQ  | Branch on Result Zero                      | PLA                   | Pull Accumulator from Stack                  |
| (2)          | BIT  | Test Bits in Memory with Accumulator       | PLP                   | Pull Processor Status from Stack             |
|              | BMI  | Branch on Result Minus                     | (1) PLX               | Pull X Register from Stack                   |
|              | BNE  | Branch on Result not Zero                  | (1) PLY               | Pull Y Register from Stack                   |
|              | BPL  | Branch on Result Plus                      |                       | <b>.</b>                                     |
| (1)          | BRA  | Branch Always                              | (1)(3) RMB            | Reset Memory Bit                             |
|              | BRK  | Force Break                                | ROL                   | Rotate One Bit Left (Memory or Accumulator)  |
|              | BVC  | Branch on Overflow Clear                   | ROR                   | Rotate One Bit Right (Memory or Accumulator) |
|              | BVS  | Branch on Overflow Set                     | RTI                   | Return from Interrupt                        |
|              |      |                                            | RTS                   | Return from Subroutine                       |
|              | CLC  | Clear Carry Flag                           |                       |                                              |
|              | CLD  | Clear Decimal Mode                         | (2) SBC               | Subtract Memory from Accumulator with Borrow |
|              | CLI  | Clear Interrupt Disable Bit                | SEC                   | Set Carry Flag                               |
|              | CLV  | Clear Overflow Flag                        | SED                   | Set Decimal Mode                             |
| (2)          | CMP  | Compare Memory and Accumulator             | SEI                   | Set Interrupt Disable Status                 |
|              | CPX  | Compare Memory and Index X                 | (1)(3) SMB            | Set Memory Bit                               |
|              | CPY  | Compare Memory and Index Y                 | (2) STA               | Store Accumulator in Memory                  |
| (0)          |      |                                            | STX                   | Store Index X in Memory                      |
| (2)          | DEC  | Decrement Memory by One                    | STY                   | Store Index Y in Memory                      |
|              | DEX  | Decrement Index X by One                   | (1) STZ               | Store Zero                                   |
|              | DEY  | Decrement Index Y by One                   |                       |                                              |
|              | 10   |                                            | TAX                   | Transfer Accumulator to Index X              |
| (2)          | EOR  | Exclusive-OR Memory with Accumulator       | TAY                   | Transfer Accumulator to Index Y              |
|              |      |                                            | (1) TRB               | Test and Reset Bits                          |
| (2)          | INC  | Increment Memory by One                    | (1) TSB               | Test and Set Bits                            |
|              | INX  | Increment Index X by One                   | TSX                   | Transfer Stack Pointer to Index X            |
|              | INY  | Increment Index Y by One                   | TXA                   | Transfer Index X to Accumulator              |
| ( <b>a</b> ) |      |                                            | TXS                   | Transfer Index X to Stack Register           |
| (2)          | JMP  | Jump to New Location                       | TYA                   | Transfer Index Y to Accumulator              |
|              | JSR  | Jump to New Location Saving Return Address |                       |                                              |
| (0)          |      |                                            |                       |                                              |
| (2)          | LDA  | Load Accumulator with Memory               |                       |                                              |
|              | LDX  | Load Index X with Memory                   | a shekara             |                                              |
|              | LDY  | Load Index Y with Memory                   | and the second states |                                              |
|              | LSH  | Snin One Bit Right (Memory or Accumulator) |                       |                                              |

#### Notes:

(1) CMOS Instruction not available on NMOS family.

(2) Previous NMOS instruction with additional addressing mode(s) added to the CMOS family.

(3) VL65C02 instruction not available on VL65NCO2



## TABLE 6. HEXADECIMAL CODES (NEW CMOS FAMILY INSTRUCTIONS)

| Hex        | Mnemonic | Description                                            |
|------------|----------|--------------------------------------------------------|
| 80         | BRA      | Branch Relative Always (Relative)                      |
| 3A         | DEC      | Decrement Accumulator (Accum)                          |
| 1A         | INC      | Increment Accumulator (Accum)                          |
| DA         | PHX      | Push X on Stack (Implied)                              |
| 5A         | PHY      | Push Y on Stack (Implied)                              |
| FA         | PLX      | Pull X from Stack (Implied)                            |
| 7 <b>A</b> | PLY      | Pull Y from Stack (Implied)                            |
| 9C         | STZ      | Store Zero (Absolute)                                  |
| 9E         | STZ      | Store Zero (ABS, X)                                    |
| 64         | STZ      | Store Zero (ZP)                                        |
| 74         | STZ      | Store Zero (ZP, X)                                     |
| 1C         | TRB      | Test and Reset Memory Bits with Accumulator (Absolute) |
| 14         | TRB      | Test and Reset Memory Bits with Accumulator (ZP)       |
| 0C         | TSB      | Test and Set Memory Bits with Accumulator (Absolute)   |
| 04         | TSB      | Test and Set Memory Bits with Accumulator (ZP)         |
| 89         | BIT      | Test Immediate with Accumulator (IMM)                  |
| 0F-7F(1)   | BBR      | Branch on Bit Reset (Bit Manipulation, ZP)             |
| 8F-FF(1)   | BBS      | Branch on Bit Set (Bit Manipulation, ZP)               |
| 07-77(1)   | RMB      | Reset Memory Bit (Bit Manipulation, ZP)                |
| 87-F7(1)   | SMB      | Set Memory Bit (Bit Manipulation, ZP)                  |

Note:

(1) Most significant digit change only. Instruction not available on VL65C02.

## TABLE 7. HEXADECIMAL CODES (INSTRUCTIONS WITH NEW CMOS ADDRESSING MODES)

| Hex | Mnemonic | Description                                         |  |
|-----|----------|-----------------------------------------------------|--|
| 72  | ADC      | Add Memory to Accumulator with Carry [(ZP)]         |  |
| 32  | AND      | AND Memory with Accumulator [(ZP)]                  |  |
| 3C  | BIT      | Test Memory Bits with Accumulator [ABS, X]          |  |
| 34  | BIT      | Test Memory Bits with Accumulator [ZP, X]           |  |
| D2  | CMP      | Compare Memory and Accumulator [(ZP)]               |  |
| 52  | EOR      | Exclusive-OR Memory with Accumulator [(ZP)]         |  |
| 7C  | JMP      | Jump (New addressing mode) [(IND), X]               |  |
| B2  | LDA      | Load Accumulator with Memory [(ZP)]                 |  |
| 12  | ORA      | OR Memory with Accumulator [(ZP)]                   |  |
| F2  | SBC      | Subtract Memory from Accumulator with Borrow [(ZP)] |  |
| 92  | STA      | Store Accumulator in Memory [(ZP)]                  |  |

## VL65C02•VL65NC02

## **TABLE 8. INSTRUCTION SET OPCODE MATRIX**

The following matrix shows the 210 op codes associated with the VL65(N)C02 family of CPU devices. The matrix identifies the hexadecimal code, the addressing mode, and the number of machine cycles associated with each op code.

| ي ل        | SD 0                     | 1.                       | 2                    | 3    | 4                   | 5                    | 6                   | 7                 | 8                     | 9                      | Α                     | в                | С                        | D                      | E                     | F                   |   |
|------------|--------------------------|--------------------------|----------------------|------|---------------------|----------------------|---------------------|-------------------|-----------------------|------------------------|-----------------------|------------------|--------------------------|------------------------|-----------------------|---------------------|---|
| ¥<br>0     | BRK<br>Implied<br>1 7    | ORA<br>(IND, X)<br>2 6   |                      |      | TSB<br>ZP<br>2 5    | ORA<br>ZP<br>2 3     | ASL<br>ZP<br>2 5    | RMB0<br>ZP<br>2 5 | PHP<br>Implied<br>1 3 | ORA<br>IMM<br>2 2      | ASL<br>Accum<br>1 2   |                  | TSB<br>ABS<br>3 6        | ORA<br>ABS<br>3 4      | ASL<br>ABS<br>3 6     | BBR0<br>ZP<br>3 5** | c |
| , <b>1</b> | BPL<br>Relative<br>2 2** | ORA<br>(IND), Y<br>2 5*  | ORA<br>(IND)<br>2 5  |      | TRB<br>ZP<br>2 5    | ORA<br>ZP, X<br>2 4  | ASL<br>ZP, X<br>2 6 | RMB1<br>ZP<br>2 5 | CLC<br>Implied<br>1 2 | ORA<br>ABS, Y<br>3 4*  | INC<br>Accum<br>1 2   |                  | TRB<br>ABS<br>3 6        | ORA<br>ABS, X<br>3 4*  | ASL<br>ABS, X<br>3 7  | BBR1<br>ZP<br>3 5** | 1 |
| 2          | JSR<br>ABS<br>3 6        | AND<br>(IND, X)<br>2 6   |                      |      | BIT<br>ZP<br>2 3    | AND<br>ZP<br>2 3     | ROL<br>ZP<br>2 5    | RMB2<br>ZP<br>2 5 | PLP<br>Implied<br>1 4 | AND<br>IMM<br>2 2      | ROL<br>Accum<br>1 2   |                  | BIT<br>ABS<br>3 4        | AND<br>ABS<br>3 4      | ROL<br>ABS<br>3 6     | BBR2<br>ZP<br>3 5** | 2 |
| 3          | BMI<br>Relative<br>2 2** | AND<br>(IND), Y<br>2 5*  | AND<br>(IND)<br>2 5  |      | BIT<br>ZP, X<br>2 4 | AND<br>ZP, X<br>2 4  | ROL<br>ZP, X<br>2 6 | RMB3<br>ZP<br>2 5 | SEC<br>Implied<br>1 2 | AND<br>ABS, Y<br>3 4'  | DEC<br>Accum<br>1 2   |                  | BIT<br>ABS, X<br>3 4*    | AND<br>ABS, X<br>3 4*  | ROL<br>ABS, X<br>3 7  | BBR3<br>ZP<br>3 5** | з |
| 4          | RTI<br>Implied<br>1 6    | EOR<br>(IND, X)<br>2 6   |                      |      |                     | EOR<br>ZP<br>2 3     | LSR<br>ZP<br>2 5    | RMB4<br>ZP<br>2 5 | PHA<br>Implied<br>1 3 | EOR<br>IMM<br>2 2      | LSR<br>Accum<br>1 2   |                  | JMP<br>ABS<br>3 3        | EOR<br>ABS<br>3 4      | LSR<br>ABS<br>3 6     | BBR4<br>ZP<br>3 5** | 4 |
| 5          | BVC<br>Relative<br>2 2** | EOR<br>(IND), Y<br>2 5*  | EOR<br>(IND)<br>2 5  |      |                     | EOR<br>ZP, X<br>2 4  | LSR<br>ZP, X<br>2 6 | RMB5<br>ZP<br>2 5 | CLI<br>Implied<br>1 2 | EOR<br>ABS, Y<br>3 4*  | PHY<br>Implied<br>1 3 |                  |                          | EOR<br>ABS, X<br>3 4*  | LSR<br>ABS, X<br>3 7  | BBR5<br>ZP<br>3 5** | 5 |
| 6          | RTS<br>Implied<br>1 6    | ADC<br>(IND, X)<br>2 6†  |                      |      | STZ<br>ZP<br>2 3    | ADC<br>ZP<br>2 3†    | ROR<br>ZP<br>2 5    | RMB6<br>ZP<br>2 5 | PLA<br>Implied<br>1 4 | ADC<br>IMM<br>2 2†     | ROR<br>Accum<br>1 2   |                  | JMP<br>(ABS)<br>3 6      | ADC<br>ABS<br>3 4†     | ROR<br>ABS<br>3 6     | BBR6<br>ZP<br>3 5** | e |
| 7          | BVS<br>Relative<br>2 2** | ADC<br>(IND), Y<br>2 5*† | ADC<br>(IND)<br>2 5† |      | STZ<br>ZP, X<br>2 4 | ADC<br>ZP, X<br>2 4† | ROR<br>ZP, X<br>2 6 | RMB7<br>ZP<br>2 5 | SEI<br>Implied<br>1 2 | ADC<br>ABS, Y<br>3 4*† | PLY<br>Implied<br>1 4 |                  | JMP<br>(ABS, X)<br>3 6   | ADC<br>ABS, X<br>3 4*† | ROR<br>ABS, X<br>3 7  | BBR7<br>ZP<br>3 5** | 7 |
| 8          | BRA<br>Relative<br>2 3*  | STA<br>(IND, X)<br>2 6   |                      |      | STY<br>ZP<br>2 3    | STA<br>ZP<br>2 3     | STX<br>ZP<br>2 3    | SMB0<br>ZP<br>2 5 | DEY<br>Implied<br>1 2 | BIT<br>IMM<br>2 2      | TXA<br>Implied<br>1 2 |                  | STY<br>ABS<br>3 4        | STA<br>ABS<br>3 4      | STX<br>ABS<br>3 4     | BBS0<br>ZP<br>3 5** | 8 |
| 9          | BCC<br>Relative<br>2 2** | STA<br>(IND), Y<br>2 6   | STA<br>(IND)<br>2 5  | ·    | STY<br>ZP, X<br>2 4 | STA<br>ZP, X<br>2 4  | STX<br>ZP, Y<br>2 4 | SMB1<br>ZP<br>2 5 | TYA<br>Implied<br>1 2 | STA<br>ABS, Y<br>3 5   | TXS<br>Implied<br>1 2 |                  | STZ<br>ABS<br>3 4        | STA<br>ABS, X<br>3 5   | STZ<br>ABS, X<br>3 5  | BBS1<br>ZP<br>3 5** | 9 |
| A          | LDY<br>IMM<br>2 2        | LDA<br>(IND, X)<br>2 6   | LDX<br>IMM<br>2 2    |      | LDY<br>ZP<br>2 3    | LDA<br>ZP<br>2 3     | LDX<br>ZP<br>2 3    | SMB2<br>ZP<br>2 5 | TAY<br>Implied<br>1 2 | LDA<br>IMM<br>2 2      | TAX<br>Implied<br>1 2 | ·······          | LDY<br>ABS<br>3 4        | LDA<br>ABS<br>3 4      | LDX<br>ABS<br>3 4     | BBS2<br>ZP<br>3 5** | 4 |
| в          | BCS<br>Relative<br>2 2** | LDA<br>(IND), Y<br>2 5*  | LDA<br>(IND)<br>2 5  |      | LDY<br>ZP, X<br>2 4 | LDA<br>ZP, X<br>2 4  | LDX<br>ZP, Y<br>2 4 | SMB3<br>ZP<br>2 5 | CLV<br>Implied        | LDA<br>ABS, Y<br>3 4*  | TSX<br>Implied        |                  | LDY<br>ABS, X<br>3 4*    | LDA<br>ABS, X<br>3 4*  | LDX<br>ABS, Y<br>3 4* | BBS3<br>ZP<br>3 5** | E |
| С          | CPY<br>IMM<br>2 2        | CMP<br>(IND, X)<br>2 6   |                      |      | CPY<br>ZP<br>2 3    | CMP<br>ZP<br>2 3     | DEC<br>ZP<br>2 5    | SMB4<br>ZP<br>2 5 | INY<br>Implied<br>1 2 | CMP<br>IMM<br>2 2      | DEX<br>Implied        |                  | CPY<br>ABS<br>3 4        | CMP<br>ABS<br>3 4      | DEC<br>ABS<br>3 6     | BBS4<br>ZP<br>3 5** | c |
| D          | BNE<br>Relative<br>2 2** | CMP<br>(IND), Y<br>2 5*  | CMP<br>(IND)<br>2 5  |      |                     | CMP<br>ZP, X<br>2 4  | DEC<br>ZP, X<br>2 6 | SMB5<br>ZP<br>2 5 | CLD<br>Implied<br>1 2 | CMP<br>ABS, Y<br>3 4*  | PHX<br>Implied<br>1 3 |                  |                          | CMP<br>ABS, X<br>3 4*  | DEC<br>ABS, X<br>3 7  | BBS5<br>ZP<br>3 5** | C |
| E          | CPX<br>IMM<br>2 2        | SBC<br>(IND, X)<br>2 6†  |                      |      | CPX<br>ZP<br>2 3    | SBC<br>ZP<br>2 3†    | INC<br>ZP<br>2 5    | SMB6<br>ZP<br>2 5 | INX<br>Implied<br>1 2 | SBC<br>IMM<br>2 2†     | NOP<br>Implied<br>1 2 |                  | CPX<br>ABS<br>3 4        | SBC<br>ABS<br>3 4†     | INC<br>ABS<br>3 6     | BBS6<br>ZP<br>3 5** | E |
| F          | BEQ<br>Relative<br>2 2** | SBC<br>(IND), Y<br>2 5*† | SBC<br>(IND)<br>2 5† | - N. |                     | SBC<br>ZP, X<br>2 4† | INC<br>ZP, X<br>2 6 | SMB7<br>ZP<br>2 5 | SED<br>Implied<br>1 2 | SBC<br>ABS, Y<br>3 4*† | PLX<br>Implied<br>1 4 |                  |                          | SBC<br>ABS, X<br>3 4*† | INC<br>ABS, X<br>3 7  | BBS7<br>ZP<br>3 5** | F |
|            | 0                        | 1                        | 2                    | 3    | 4                   | 5                    | 6                   | 7                 | 8                     | 9                      | A                     | В                | С                        | D                      | E                     | F                   |   |
| ſ          |                          |                          |                      |      | 0<br>BR             | K —                  | OP Code             | e<br>Ing Mode     |                       |                        |                       | †Add 1<br>*Add 1 | to N if in<br>to N if pi | decimal r<br>age bound | node.<br>lary is cro  | ssed.               |   |



Add 2 to N if branch occurs to different page.

Note: All of the op codes in column 7 and column F are interpreted as a NOP in the VL65NC02.

1 7

- New Opcode

VL65C02•VL65NC02 🔻

## CRYSTAL/CLOCK CONSIDERATIONS

Figure 1 shows a time base generation scheme for 4 MHz operation of the VL65C02 or VL65NC02 that has been tested and proven reliable for normal environments. As with any clock oscillator circuit, stray capacitance due to board layout can cause unpredictable results requiring "fine tuning" of the circuit. Figure 2 shows a possible external clock scheme for standby mode. Table 9 identifies nominal crystal parameters for five crystal frequencies.

## **TABLE 9. CRYSTAL PARAMETERS**

|           |      | Frequency (MHz) |           |           |           |       |  |  |  |
|-----------|------|-----------------|-----------|-----------|-----------|-------|--|--|--|
| Parameter | 3.58 | 4.0             | 6.0       | 8.0       | 10.0      | Units |  |  |  |
| RS        | 60   | 50              | 30-50     | 20-40     | 10-30     | Ω     |  |  |  |
| C0        | 3.5  | 6.5             | 4-6       | 4-6       | 3-5       | pF    |  |  |  |
| C1        | 0.15 | 0.025           | 0.01-0.02 | 0.01-0.02 | 0.01-0.02 | pF    |  |  |  |
| Q         | 740K | 730K            | 720K      | 720K      | 720K      |       |  |  |  |

Note: AT-cut crystal parameters only. Ot hers may be used.

## FIGURE 1. TIME BASE GENERATOR



Note: CTS Knights MP Series or equivalent.

## FIGURE 2. STANDBY MODE



## STOPPING THE CLOCK-STANDBY MODE

Caution must be exercised when configuring the VL65C02 or VL65NC02 in the standby mode (i.e., Ø0 (IN) clock stopped). The input clock can be held in the HIGH state indefinitely; however, if the input clock is held in the LOW state longer than five microseconds, internal register and data status can be lost. Figure 2 shows a circuit that stops the Ø0 (IN) (VL65C02 or VL65NC02) clock in the HIGH state during standby mode.

# VL65C02-VL65NC02

## FIGURE 3. TIMING DIAGRAM



Note: All timing is referenced from a HIGH level of 2.4 volts and a LOW level of 0.5 volts.



## A C CHARACTERISTICS: TA = $0^{\circ}$ C to +70°C, VCC = +5 V ± 5%

## CLOCK TIMING

|        |                           | 11   | 1 MHz   |      | 2 MHz   |      | 3 MHz   |      | 4 MHz   |       |
|--------|---------------------------|------|---------|------|---------|------|---------|------|---------|-------|
| Symbol | Parameter                 | Min  | Max     | Min  | Max     | Min  | Max     | Min  | Max     | Units |
| tCYC   | Ø2 Cycle Time             | 1000 | Note(1) | 500  | Note(1) | 333  | Note(1) | 250  | Note(1) | ns    |
| tCL    | Ø2 LOW Pulse Width        | 430  | 5000    | 210  | 5000    | 150  | 5000    | 100  | 5000    | ns    |
| iCH    | Ø2 HIGH Pulse Width       | 450  | -       | 220  |         | 160  | -       | 110  | -       | ns    |
| tSK2   | Ø0 to Ø2 LOW Skew         | -    | 50      | -    | 50      | -    | 40      | -    | 30      | ns    |
| tSK1   | Ø2 LOW to Ø1 HIGH Skew    | - 20 | 20      | - 20 | 20      | - 20 | 20      | - 20 | 20      | ns    |
| tR, tF | Clock Rise and Fall Times | -    | 25      | -    | 20      | -    | 15      | -    | 12      | ns    |

### **READ/WRITE TIMING**

|        |                       | 11  | MHz | 2 MHz |     | 3 MHz |     | 4 MHz |     |       |
|--------|-----------------------|-----|-----|-------|-----|-------|-----|-------|-----|-------|
| Symbol | Parameter             | Min | Max | Min   | Max | Min   | Max | Min   | Max | Units |
| tRWS   | R/W Setup Time        | - 1 | 125 | -     | 100 | -     | 75  | -     | 60  | ns    |
| tHRW   | R/W Hold Time         | 15  | -   | 15    | - 1 | 15    | - · | 15    | -   | ns    |
| tADS   | Address Setup Time    | -   | 125 | -     | 100 | -     | 75  | -     | 60  | ns    |
| tHA    | Address Hold Time     | 15  | -   | 15    | -   | 15    | -   | 15    | -   | ns    |
| tACC   | Read Access Time      | 775 | -   | 340   | -   | 215   | -   | 160   | -   | ns    |
| tDSU   | Read Data Setup Time  | 100 | -   | 60    | -   | 40    |     | 30    | - : | ns    |
| tHR    | Read Data Hold Time   | 10  | -   | 10    | -   | 10    | -   | 10    | -   | ns    |
| tMDS   | Write Data Delay Time | -   | 200 | -     | 110 | -     | 85  | -     | 55  | ns    |
| tHW    | Write Data Hold Time  | 30  | -   | 30    | -   | 30    | -   | 30    | -   | ns    |

## CONTROL SIGNAL TIMING

|        |                     | 11  | 1 MHz |     | 2 MHz |     | 3 MHz |     | 4 MHz |       |
|--------|---------------------|-----|-------|-----|-------|-----|-------|-----|-------|-------|
| Symbol | Parameter           | Min | Max   | Min | Max   | Min | Max   | Min | Max   | Units |
| tSYS   | SYNC Delay          | -   | 125   | -   | 100   | -   | 75    | -   | 60    | ns    |
| tRDS   | RDY Setup Time      | 200 | · · - | 110 | -     | 80  | -     | 60  | -     | ns    |
| tSOS   | SO Setup Time       | 75  | -     | 50  | -     | 40  | -     | 30  | -     | ns    |
| tIS    | IRQ, RES Setup Time | 200 | -     | 110 | -     | 80  | -     | 60  | -     | ns    |
| tNMI   | NMI Setup Time      | 200 | -     | 150 | -     | 100 | -     | 70  | -     | ns    |

## Notes:

(1) VL65C02 and VL65NC02 minimum operating frequency is limited by Ø2 low pulse width. The processors can be stopped with Ø2 held high.

# VL65C02-VL65NC02

## ABSOLUTE MAXIMUM RATINGS

| Ambient Operating<br>Temperature - Comm | ercial 0°C to +70°C |
|-----------------------------------------|---------------------|
| - Industi                               | rial -40°C to +85°C |
| Storage Temperature                     | -65°C to +150°C     |
| Supply Voltage to<br>Ground Potential   | -0.3 to +7.0 V      |
| Applied Output<br>Voltage               | -0.3 to VCC + 0.3 V |
| Applied Input<br>Voltage                | -0.3 to VCC + 0.3 V |

Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only. Functional operation of this device at these or other conditions above those indicated in the operational sections of this specification is not implied and exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D.C. CHARACTERISTICS: TA = 0°C to +70°C, VCC = +5.0 V ± 5% (Notes 1, 2, 3)

| Symbol                       | Parameter                                               |                           | Min  | Тур                | Max       | Units  | Test Conditions                        |
|------------------------------|---------------------------------------------------------|---------------------------|------|--------------------|-----------|--------|----------------------------------------|
|                              |                                                         | Ø0 (IN)                   | 2.4  | -                  | VCC + 0.3 | v      |                                        |
| VIE                          | input hiGH voltage                                      | All Other Inputs          | 2.0  | -                  | VCC + 0.3 | V      |                                        |
| 1/11                         |                                                         | Ø0 (IN)                   | -0.3 | -                  | + 0.4     | v      |                                        |
| VIL                          |                                                         | All Other Inputs          | -0.3 | -                  | + 0.8     | v      |                                        |
| n an an an Arban<br>An Arban |                                                         | Ø0 (IN)                   |      | -                  | 1.0       | μA     |                                        |
| lin                          | Input Leakage<br>Current                                | NMI, IRO, RDY,<br>RES, SO |      | -                  | -50       | μА     | VIIV = 0 V 10 + 5.25 V<br>VCC = 0 V    |
| ITSI                         | Three-State (Off-State) Input Current<br>D7 - D0        |                           | -    | -                  | 10        | μA     | VIN = 0.4 V to +2.4 V<br>VCC = +5.25 V |
| VOH                          | Output HIGH Voltage<br>SYNC, D7-D0, A15-A0, R/W, Ø1, Ø2 |                           | 2.4  |                    | -         | V      | VCC = +4.75 V<br>ILOAD = -100 μA       |
| VOL                          | Output LOW Voltage<br>SYNC, D7-D0, A15-                 | a0, R/W, Ø1, Ø2           |      | -                  | +0.4      | v      | VCC = +4.75 V<br>ILOAD = 1.6 μA        |
|                              |                                                         | Standby (4)               | -    | 2.0                | 10        | μA     | VCC = +5.0 V                           |
|                              | Supply Current                                          | Active (5)                | -    | 2.6                | -         | mA/MHz |                                        |
| 100                          | Supply Current                                          | Active (6)                | -    | - <sup>-</sup>     | 10        | mA     |                                        |
|                              |                                                         | Low Power                 | -    | 1.1                | -         | mA/MHz | RDY = 0 V                              |
| -                            |                                                         | NMI, IRQ, SO, RDY         | -    | -                  | 7         | pF     | V00                                    |
| Cill                         | in input Capacitance                                    | Ø0 (IN)                   | -    | , 5 x <del>-</del> | 30        | pF     | VCC = +5.0 V,<br>VIN = 0 V,            |
| CIO                          | I/O Capacitance - D7-D0, Ø1, Ø2                         |                           |      | -                  | 10        | pF     | f = 1 MHz,<br>TA = 25°C                |
| COUT                         | Output Capacitance                                      | - A15-A0, R/W, SYNC       | •    | -                  | 10        | pF     |                                        |

#### Notes:

- (1) All units are direct current (D.C.).
- (2) A negative sign indicates outward current flow, positive indicates inward flow.
- (3) IRQ and NMI require an external pull-up resistor.

(4) Typical values are shown for VCC = +5.0 V and TA =  $+25^{\circ}$ C.

- (5) Typical value for power estimation only; dependent on frequency of operation.
- (6) Maximum value for power consumption; independent of frequency of operation.



## **CMOS 16-BIT MICROPROCESSOR FAMILY**

## FEATURES

- Advanced CMOS design for low power consumption and increased noise immunity
- Single 3 6 V power supply, 5 V specified
- Emulation mode allows complete hardware and software compatibility with 6502 designs
- 24-bit address bus allows access to 16M Bytes of memory space
- Full 16-bit ALU, Accumulator, Stack Pointer, and Index Registers
- Valid Data Address (VDA) and Valid Program Address (VPA) output allows dual cache and cycle steal DMA implementation
- Vector Pull (VP) output indicates when interrupt vectors are being addressed
- May be used to implement vectored interrupt design
- ABORT input and associated vector supports interrupting any instruction without modifying internal registers
- Separate program and data bank registers allow program segmentation

PIN DIAGRAMS

- New Direct Register allows "zero page" addressing anywhere in first 64K bytes
- 24 addressing modes: 13 original 6502 modes plus 11 new addressing modes, with 91 instructions using 255 opcodes
- New Wait for Interrupt (WAI) and Stop the Clock (STP) instructions further reduce power consumption, decrease interrupt latency and allow synchronization with external events
- New Co-Processor instruction (COP) with associated vector supports coprocessor configurations (i.e., floating point processors)

## DESCRIPTION

The VLSI VL65C802 and VL65C816 are CMOS 16-bit microprocessors featuring total software compatibility with their 8bit NMOS and CMOS 6500-series predecessors. The VL65C802 is pin-forpin compatible with 8-bit devices currently available, while the VL65C816 extends addressing to a full 16 megabytes. These devices offer the many advantages of CMOS technology, including increased noise immunity, higher reliability, and greatly reduced power requirements. A software switch determines whether the processor is in the 8-bit "emulation" mode or in the "native" mode, thus allowing existing systems to use the expanded features.

The Accumulator, ALU, X and Y Index registers, and Stack Pointer Register have all been extended to 16 bits. A new 16-bit Direct PageRegister augments the Direct Page addressing mode (formerly Zero Page addressing). Separate Program Bank and Data Bank Registers allow 24-bit memory addressing.

Four new signals provide the system designer with many options. The ABORT input can interrupt the currently executing instruction without modifying internal registers. Valid Data Address (VDA) and Valid Program Address (VPA) outputs facilitate dual cache memory by indicating whether a data segment or program segment is accessed. Modifying a vector is made easy by monitoring the Vector Pull (VP) output.

## **ORDER INFORMATION**

|                        | VL65C816                     | 5                                               |                                   | VL65C802                                                  |                                                                                     | Part<br>Number                                                                    | Clock<br>Frequency | Package                                                                 |
|------------------------|------------------------------|-------------------------------------------------|-----------------------------------|-----------------------------------------------------------|-------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|--------------------|-------------------------------------------------------------------------|
|                        | 1 4<br>2 3<br>3 3<br>4 3     | 0   RES<br>9   VDA<br>18   M/X<br>17   \$2 (IN) | Vss<br>RDY<br>\$\$1 (OUT)<br>IRQ  | 1 40<br>2 39<br>3 38<br>4 37                              | <ul> <li>□ RES</li> <li>□ \$\$0</li> <li>□ \$\$0</li> <li>□ \$\$2\$ (IN)</li> </ul> | VL65C802-02PC<br>VL65C802-02CC<br>VL65C816-02PC<br>VL65C816-02CC<br>VL65C802-04PC | 2 MHz              | Plastic DIP<br>Ceramic DIP<br>Plastic DIP<br>Ceramic DIP<br>Plastic DIP |
|                        | 5 3<br>6 3<br>7 3<br>8 3     | 6 3 8E<br>5 3 E<br>44 3 R/W<br>3 3 00/BA0       |                                   | 5 36<br>6 35<br>7 34<br>8 33                              |                                                                                     | VL65C802-04CC<br>VL65C816-04PC<br>VL65C816-04CC                                   | 4 MHz              | Ceramic DIP<br>Plastic DIP<br>Ceramic DIP                               |
| A0                     | 9 3<br>10 3<br>11 3          | 12 D1/BA1<br>12 D2/BA2<br>10 D3/BA3             |                                   | 9 32<br>0 31<br>1 30<br>2 29                              | D1<br>D2<br>D3                                                                      | VL65C802-06PC<br>VL65C802-06CC<br>VL65C816-06PC<br>VL65C816-06CC                  | 6 MHz              | Plastic DIP<br>Ceramic DIP<br>Plastic DIP<br>Ceramic DIP                |
| A4<br>A5<br>A6<br>A7   | 13 2<br>14 2<br>15 2<br>16 2 | 28 D5/BA5<br>27 D6/BA6<br>26 D7/BA7<br>25 A15   | A4 []<br>A5 []<br>A6 []<br>A7 []  | 3 28<br>4 27<br>5 26<br>6 25                              | D5<br>D6<br>D7<br>A15                                                               | VL65C802-08PC<br>VL65C802-08CC<br>VL65C816-08PC<br>VL65C816-08CC                  | 8 MHz              | Plastic DIP<br>Ceramic DIP<br>Plastic DIP<br>Ceramic DIP                |
| A8<br>A9<br>A10<br>A11 | 17 2<br>18 2<br>19 2<br>20 2 | 24 A14<br>23 A13<br>22 A12<br>21 Vss            | A8 11<br>A9 11<br>A10 11<br>A11 2 | 17     24       18     23       19     22       20     21 | A14<br>A13<br>A12<br>V\$\$                                                          |                                                                                   |                    |                                                                         |



## **BLOCK DIAGRAM**



## **FIGURE 1. STATUS REGISTER**



## FIGURE 2. PROGRAMMING MODEL

| 8 BITS            | 8 BITS                                  | 8 BITS                    |  |  |
|-------------------|-----------------------------------------|---------------------------|--|--|
| Data Bank Reg.    | X Register Hi                           | () X Register Low         |  |  |
| (DBR)             | (XH) ()                                 | (XL)                      |  |  |
| Data Bank Reg.    | Y Register Hi                           | () Y Register Low         |  |  |
| (DBR)             | (YH)                                    | (YL)                      |  |  |
| 00                | Stack Register Hi <sub>(S</sub><br>(SH) | S) Stack Reg. Low<br>(SL) |  |  |
| = 6502            | Accumulator (C                          | ) Accumulator             |  |  |
| Registers         | (B)                                     | (A)                       |  |  |
| Program Bank Reg. | Program                                 | C) Counter                |  |  |
| (PBR)             | (PCH) (P                                | (PCL)                     |  |  |
| 00                | Direct Reg. Hi<br>(DH) (I               | Direct Reg. Low<br>(DL)   |  |  |

## SIGNAL DESCRIPTIONS

| Signal<br>Name                                    | Signal<br>Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Abort (ABORT)<br>(VL65C816)                       | The Abort input is used to abort instructions (usually due to an Address Bus condition). A negative transition will inhibit modification of any internal register during the current instruction. Upon completion of this instruction, an interrupt sequence is initiated. The location of the aborted opcode is stored as the return address in stack memory. The Abort vector address is 00FFF8, 9 (Emulation Mode) or 00FFE8. 9 (Native mode). Since <u>ABORT</u> is an edge-sensitive input, an Abort occurs whenever there is a negative pulse (or level) on the <u>ABORT</u> line during a phase 2 clock.                                                                |
| Address Bus (A0-A15)                              | These 16 output lines form the Address Bus for memory and I/O exchange on the Data Bus When<br>using the VL65C816, the address lines may be set to the high-impedance state by the Bus Enable (BE)<br>signal.                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Bus Enable (BE)<br>(VL65C816)                     | The Bus Enable input signal allows external control of the Address and Data Buffers, as well as the $R/W$ signal. With Bus Enable high, the $R/W$ and Address Buffers are active. The Data/Address Buffers are active during the first half of every cycle and the second half of a write cycle. When BE is low, these buffers are disabled. Bus Enable is an asynchronous signal.                                                                                                                                                                                                                                                                                             |
| Data Bus (D0-D7)<br>(VL65C802)                    | The eight Data Bus lines provide an 8-bit bidirectional Data Bus for use during data exchange between<br>the microprocessor and external memory or peripherals. Two memory cycles are required for the<br>transfer of 16-bit values.                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Data/Address Bus<br>(D0/BA0-D7/BA7)<br>(VL65C816) | These eight lines multiplex address bits BA0-BA7 with the data value. The address is present during<br>the first half of a memory cycle, and the data value is read or written during the second half of the<br>memory cycle. Two memory cycles are required to transfer 16-bit values. These lines may be set to the<br>high impedance state by the BE signal.                                                                                                                                                                                                                                                                                                                |
| Emulation Status (E)<br>(VL65C816)                | The Emulation Status output reflects the state of the Emulation (E) Mode flag in the Processor Status (P) Register. This signal may be thought of as an op code extension and used for memory and system management.                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Interrupt Request<br>(IRQ)                        | The Interrupt Request input signal is used to request that an interrupt sequence be initiated. When the IRQ Disable (I) Flag is cleared, a low input logic level initiates an interrupt sequence after the current instruction is completed. The Wait for Interrupt (WAI) instruction may be executed to ensure the interrupt is recognized immediately. The Interrupt Request vector address is 00FFFE,F (Emulation Mode) or 00FFEE,F (Native mode). Since IRQ is a level-sensitive input, an interrupt occurs if the interrupt source was not cleared since the last interrupt. Also, no interrupt occurs if the interrupt source is cleared prior to interrupt recognition. |
| Memory Lock (ML)<br>(VL65C816)                    | The Memory Lock output may be used to ensure the integrity of Read-Modify-Write instructions in a multiprocessor system. Memory Lock indicates the need to defer arbitration of the next bus cycle. Memory Lock is low during the last three or five cycles of ASL, DEC, INC, LSR, ROL, ROR, TRB, and TSB memory referencing instructions, depending on the state of the M flag.                                                                                                                                                                                                                                                                                               |
| Memory/Index Select<br>Status (M/X)<br>(VL65C816) | This multiplexed output reflects the state of the Accumulator (M) and Index (X) Select Flags (bits 5 and 4 of the Processor Status (P) Register). Flag M is valid during the Phase 2 clock negative transition and Flag X is valid during the Phase 2 clock positive transition. These bits may be thought of as opcode extensions and may be used for memory and system management.                                                                                                                                                                                                                                                                                           |
| Non-Mask <u>able</u><br>Interrupt (NMI)           | A negative transition on the $\overline{\text{NMI}}$ input initiates an interrupt sequence. A high-to-low transition initiates<br>an interrupt sequence after the current instruction is completed. The Wait for Interrupt (WAI)<br>instruction may be executed to ensure that the interrupt will be recognized immediately. The Non-<br>Maskable Interrupt vector address is 00FFFA,B (Emulation Mode) or 00FFEA,B (Native Mode). Since<br>$\overline{\text{NMI}}$ is an edge-sensitive input, an interrup occurs if there is a negative transition while servicing a<br>previous interrupt. Also, no interrupt occurs if $\overline{\text{NMI}}$ remains low.                |
| Phase 1 Out [ø1<br>(OUT)] (VL65C802)              | This inverted clock output signal provides timing for external read and write operations. Executing the<br>Stop (STP) instruction holds this clock in the low state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Phase 2 In [ø2 (IN)]                              | This is the system clock input to the microprocessor internal clock generator (equivalent to $Ø0$ (IN) on the 6502). During the low-power Standby Mode, $Ø2$ (IN) should be held in the high state to preserve the contents of internal registers.                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Phase 2 Out [ø2<br>(OUT)] (VL65C802)              | This clock output signal provides timing for external read and write operations. Addresses are valid<br>after the address setup time (Tads), following the negative transition of ø2 (Out). Executing the (STP)<br>instruction holds ø2 (Out) in the high state.                                                                                                                                                                                                                                                                                                                                                                                                               |

## SIGNAL DESCRIPTIONS (CONTINUED)

| Signal<br>Name                                           | Signal<br>Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Read/Write (R/W)                                         | When the $R/\overline{W}$ output signal is in the high state, the microprocessor is reading data from memory or I/O.<br>When in the low state, the Data Bus contains valid data from the microprocessor that is to be stored at<br>the addressed memory location. When using the VL65C816, the $R/\overline{W}$ signal may be set to the high<br>impedance state by Bus Enable (BE).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Ready (RDY)                                              | This bidirectional signal indicates that a Wait for Interrupt (WAI) instruction has been executed allowing the user to halt operation of the microprocessor. A low input logic level will halt the microprocessor in its current state (note that when in the Emulation Mode, the VL65C802 stops only during a read cycle). Returning RDY to the active high state allows the microprocessor to continue following the next Phase 2 In clock negative transition. The RDY signal is internally pulled low following the execution of a Wait for Interrupt (WAI) instruction, and then returned to the high state when a RES, ABORT, NMI, or IRQ external interrupt is provided. This feature may be used to eliminate interrupt latency by placing the WAI instruction is executed when the IRQ servicing routine. If the IRQ Disable Flag has been set, the next instruction is executed when the IRQ occurs. The processor does stop after a WAI instruction if RDY has been forced to a high state. The Stop (STP) instruction has no effect on RDY. |
| Reset (RES)                                              | The Reset input is used to initialize the microprocessor and start program execution. The Reset input<br>buffer has hysteresis such that a simple R-C timing circuit may be used with the internal pullup device.<br>The RES signal must be held low <u>for a</u> least two clock cycles after VDD reaches operating voltage.<br>Ready (RDY) has no effect while RES is being held low. During this Reset conditioning period, the<br>following processor initialization takes place:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                                          | Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                                          | D = 0000 SH = 01                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                                          | DBR = 00 	 XH = 00      PBR = 00 	 YH = 00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                          | N V M X D I Z C/E                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                                          | P = <u>* * 1 1 0 1 * */1</u> * = Not Initialized                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                                          | STP and WAI instructions are cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                                          | Signals                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                                          | $E = 1$ $\frac{VDA}{VP} = 1$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                                          | $R/\overline{W} = 1$ VP = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                                          | SYNC= 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                                                          | <ul> <li>When Reset is brought high, an interrupt sequence is initiated:</li> <li>R/W remains in the high state during the stack address cycles.</li> <li>The Reset vector address is 00FFFC.D.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Set Overflow (SO)                                        | A negative transition on this input sets the Overflow (V) Flag, bit 6 of the Processor Status (P) Register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| (VL65C802)<br>Synchronize (SYNC)<br>(VL65C802)           | The SYNC output is provided to identify those cycles during which the microprocessor is fetching an<br>opcode. The SYNC signal is high during an opcode fetch cycle, and when combined with Ready (RDY),<br>can be used for single instruction execution.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Valid Data Address<br>(VDA) and Valid<br>Program Address | These two output signals indicate the type of memory being accessed by the address bus. The following coding applies:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| (VPA) (VL65C816)                                         | VDA VPA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| (,(                                                      | 0 0 Internal operation - Address and Data Bus available.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                          | 0 1 Valid program address - May be used for program cache control.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                                                          | 1 0 Valid data address - May be used for data cache control.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                                          | 1 1 Op code fetch - May be used for program cache control and single<br>step control.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| VDD and VSS                                              | VDD is the positive supply voltage and VSS is system logic ground. Pin 21 of the two VSS pins on the<br>VL65C802 should be used for system ground.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Vector Pull (VP)<br>(VI 65C816)                          | The Vector Pull output indicates that a vector location is being addressed during an interrupt sequence.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

VP is low during the last two interrupt sequence cycles, during which time the processor reads the interrupt vector. The VP signal may be used to select and prioritize interrupts from several sources by modifying the vector addresses.

## FUNCTIONAL DESCRIPTION

The VL65C802 offers the design engineer the opportunity to utilize both existing software programs and hardware configurations, while also achieving the added advantages of increased register lengths and faster execution times. The VL65C802 "ease of use" design and implementation features provide the designer with increased flexibility and reduced implementation costs. In the Emulation Mode, the VL65C802 not only offers software compatibility, but is also hardware (pin-for-pin) compatible with 6502 designs. It provides the advantages of 16-bit internal operation in 6502-compatible applications. The VL65C802 is an excellent direct replacement microprocessor for 6502 designs.

The VL65C816 provides the design engineer with upward mobility and software compatibility in applications in which a 16-bit system configuration is desired. The VL65C816 16-bit hardware configuration, coupled with current software, allows a wide selection of system applications. In the Emulation Mode, the VL65C816 offers many advantages, including full software compatibility with 6502 coding. In addition, the powerful VL65C816 instruction set and addressing modes make it an excellent choice for new 16bit designs.

Internal organization of the VL65C802 and VL65C816 can be divided into two parts: 1) the Register Section, and 2) the Control Section. Instructions (or op codes) obtained from program memory are executed by implementing a series of data transfers within the Register Section. Signals that cause data transfers to be executed are generated within the Control Section. Both the VL65C802 and VL65C816 have a 16-bit internal architecture with an 8-bit external data bus.

## INSTRUCTION REGISTER

An opcode enters the processor on the Data Bus and is latched into the Instruction Register during the instruction fetch cycle. This instruction is then decoded, along with timing and interrupt signals, to generate the various Instruction Register control signals.

### TIMING CONTROL UNIT (TCU)

The Timing Control Unit keeps track of each instruction cycle as it is executed. The TCU is set to zero each time an instruction fetch is executed, and is advanced at the beginning of each cycle for as many cycles as is required to complete the instruction. Each data transfer between registers depends upon decoding the contents of both the Instruction Register and the Timing Control Unit.

ARITHMETIC LOGIC UNIT (ALU) All arithmetic and logic operations take place within the 16-bit ALU. In addition to data operations, the ALU also calculates the effective address for relative and indexed addressing modes. The result of a data operation is stored in either memory or an internal register. Carry, Negative, Overflow and Zero Flags may be updated following the ALU data operation.

INTERNAL REGISTERS (Refer to figure 2, Programming Model.)

ACCUMULATORS (A, B, C) The Accumulator is a general purpose register that stores one of the operands, or the result of most arithmetic and logical operations. In the Native Mode (E=0), when the Accumulator Select Bit (M) equals zero, the Accumulator is established as 16 bits wide (A+B=C). When the Accumulator Select Bit (M) equals one, the Accumulator is eight bits wide (A). In this case, the upper eight bits (B) may be used for temporary storage in conjunction with the Exchange B and A Accumulator (XBA) instruction.

### DATA BANK REGISTER (DBR)

During modes of operation, the 8-bit Data Bank Register holds the default bank address for memory transfers. The 24-bit address is composed of the 16-bit instruction effective address and the 8-bit Data Bank address. The register value is mulitplexed with the data value and is present on the Data/Address lines during the first half of a data transfer memory cycle for the VL65C816. The Data Bank Register is initialized to zero during Reset.

#### DIRECT (D)

The 16-bit Direct Register provides an address offset for all instructions using direct addressing. The effective bank zero address is formed by adding the 8bit instruction operand address to the Direct Register contents. The Direct Register is initialized to zero during Reset.

### INDEX (X AND Y)

There are two Index Registers (X and Y), which may be used as general-purpose registers or to provide an index value for calculation of the effective address. When executing an instruction with indexed addressing, the microprocessor fetches the opcode and the base address, and then modifies the address by adding the Index Register contents to the address prior to performing the desired operation. Pre-indexing or postindexing of indirect addresses may be selected. In the Native Mode (E=0), both Index Registers are 16 bits wide If the Index Select Bit (X) equals zero. If the Index Select Bit (X) equals one, both registers are 8 bits wide, and the high byte is forced to zero. PROCESSOR STATUS (P) The 8-bit Processor Status Register contains status flags and mode select bits. The Carry (C), Negative (N), Overflow (V), and Zero (Z) status flags serve to report the status of most ALU operations. These status flags are tested by use of Conditional Branch instructions. The Decimal (D), IRQ Disable (I), Memory/Accumulator (M), and Index (X) bits are used as mode select flags. These flags are set by the program to change microprocessor operations.

The Emulation (E) Select and the Break (B) flags are accessible only through the processor Status Register. The Emulation mode select flag is selected by the Exchange Carry and Emulation Bits (XCE) instruction. Table 1, Compatibility Issues, illustrates the features of the Native (E=0) and Emulation (E=1) Modes. The M and X flags are always equal to one in the Emulation Mode. When an interrupt occurs during the Emulation Mode, the Break Flag is written to stack memory as bit 4 of the Processor Status Register.

### PROGRAM BANK REGISTER (PBR)

The 8-bit Program Bank Register holds the bank address for all instruction fetches. The 24-bit address consists of the 16-bit instruction effective address and the 8-bit Program Bank address. The register value is multiplexed with the data value and presented on the Data/Address lines during the first half



of a program memory read cycle. The Program Bank Register is initialized to zero during Reset. The PHK instruction pushes the PBR register onto the Stack.

## PROGRAM COUNTER (PC)

The 16-bit Program Counter Register provides the addresses that are used to step the microprocessor through sequential program instructions. The register is incremented each time an instruction or operand is fetched from program memory.

## STACK POINTER (S)

The Stack Pointer is a 16-bit register that is used to indicate the next available location in the stack memory area. It serves as the effective address in stack addressing modes as well as subroutine and interrupt processing. The Stack Pointer allows simple implementation of nested subroutines and multiple-level interrupts. During the Emulation Mode, the Stack Pointer highorder byte (SH) is always equal to one. The bank address for all stack operations is bank zero.

## **PIN DESCRIPTIONS**

|                  | New York and the second se |
|------------------|----------------------------------------------------------------------------------------------------------------|
| Pin              | Description                                                                                                    |
| A0-A15           | Address Bus                                                                                                    |
| ABORT            | Abort Input                                                                                                    |
| BE               | Bus Enable                                                                                                     |
| φ2 (IN)          | Phase 2 In Clock                                                                                               |
| <i>φ</i> 1 (OUT) | Phase 1 Out Clock                                                                                              |
| ¢2 (OUT)         | Phase 2 Out Clock                                                                                              |
| D0-D7            | Data Bus                                                                                                       |
| D0/BA0-D7/BA7    | Data Bus, Multiplexed                                                                                          |
| E                | Emulation Select                                                                                               |
| IRQ              | Interrupt Request                                                                                              |
| ML               | Memory Lock                                                                                                    |
| M/X              | Mode Select (Рм or Рх)                                                                                         |
|                  |                                                                                                                |

| Pin  | Description                      |
|------|----------------------------------|
| NC   | No Connection                    |
| NMI  | Non-Maskable Interrupt           |
| RDY  | Ready                            |
| RES  | Reset                            |
| R/W  | Read/Write                       |
| SO   | Set Overflow                     |
| SYNC | Synchronize                      |
| VDA  | Valid Data Address               |
| VP   | Vector Pull                      |
| VPA  | Valid Program Address            |
| VDD  | Positive Power Supply (+5 Volts) |
| Vss  | Internal Logic Ground            |

## TABLE 1. COMPATIBILITY ISSUES

|                                                                                         | 65C816/802                                                                                                                  | 65C02                                                                              | NMOS 6502                                                                                                   |
|-----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|
| 1. S (Stack)                                                                            | Always page 1 (E = 1), 8 bits 16 bits when (E = 0).                                                                         | Always page 1, 8 bits                                                              | Always page 1, 8 bits                                                                                       |
| 2. X (X Index Register)                                                                 | Indexed page zero always in<br>page 0 (E = 1),<br>Cross page (E = 0).                                                       | Always page 0                                                                      | Always page 0                                                                                               |
| 3. Y (Y Index Register)                                                                 | Indexed page zero always in<br>page 0 (E = 1),<br>Cross page (E = 0).                                                       | Always page 0                                                                      | Always page 0                                                                                               |
| 4. A (Accumulator)                                                                      | 8 bits (M = 1), 16 bits (M = 0)                                                                                             | 8 bits                                                                             | 8 bits                                                                                                      |
| 5. P (Flag Registor)                                                                    | N, V, and Z flags valid in<br>decimal mode.<br>D = 0 after reset or interrupt.                                              | N, V, and Z flags valid in<br>decimal mode.<br>D = 0 after reset and<br>interrupt. | N, V, and Z flags invalid<br>in decimal mode.<br>D = unknown after reset.<br>D not modified after interrupt |
| <ol> <li>Timing</li> <li>ABS, X ASL, LSR, ROL,<br/>ROR With No Page Crossing</li> </ol> | 7 cycles                                                                                                                    | 6 cycles                                                                           | 7 cycles                                                                                                    |
| B. Jump Indirect<br>Operand = XXFF                                                      | 5 cycles                                                                                                                    | 6 cycles                                                                           | 5 cycles and invalid page crossing                                                                          |
| C. Branch Across Page                                                                   | 4 cycles (E = 1)<br>3 cycles (E = 0)                                                                                        | 4 cycles                                                                           | 4 cycles                                                                                                    |
| D. Decimal Mode                                                                         | No additional cycle                                                                                                         | Add 1 cycle                                                                        | No additional cycle                                                                                         |
| 7. BRK Vector                                                                           | 00FFFE,F (E = 1) BRK bit = 0<br>on stack if IRQ, NMI, ABORT.<br>00FFE6, 7 (E = 0) X = X on<br>Stack always.                 | FFFE,F BRK bit = 0 on stack<br>if IRQ, NMI.                                        | FF <u>FE</u> ,F <u>BR</u> K bit = 0 on stack<br>if IRQ, NMI.                                                |
| 8. Interrupt or Break<br>Bank Address                                                   | PBR not pushed (E = 1)<br>RTI PBR not pulled (E = 1)<br>PBR pushed (E = 0)<br>RTI PBR pulled (E = 0)                        | Not available                                                                      | Not available                                                                                               |
| 9. Memory Lock (ML)                                                                     | ML = 0 during Read, Modify and<br>Write cycles.                                                                             | ML = 0 during Modify and Write.                                                    | Not available                                                                                               |
| 10. Indexed Across Page<br>Boundary (d),y; a,x; a,y                                     | Extra read of invalid address.                                                                                              | Extra read of last instruction fetch.                                              | Extra read of invalid address.                                                                              |
| 11. RDY Pulled During Write<br>Cycle.                                                   | Ignored (E = 1) for 65C802 only.<br>Processor stops (E = 0).                                                                | Processor stops                                                                    | Ignored                                                                                                     |
| 12. WAI and STP Instructions.                                                           | Available                                                                                                                   | Available                                                                          | Not available                                                                                               |
| 13. Unused OP Codes                                                                     | One reserved OP Code specified<br>as WDM will be used in future<br>systems. The 65C816 performs<br>a no-operation.          | No operation                                                                       | Unknown and some "hang<br>up" processor.                                                                    |
| 14. Bank Address Handling                                                               | PBR = 00 after reset or interrupts.                                                                                         | Not available                                                                      | Not available                                                                                               |
| <ol> <li>R/W During Read-Modify-<br/>Write Instructions</li> </ol>                      | E = 1, R/ $\overline{W}$ = 0 during Modify and<br>Write cycles.<br>E = 0, R/ $\overline{W}$ = 0 only during<br>Write cycle. | R/W = 0 only during Write cycle                                                    | $R/\overline{W}$ = 0 during Modify and Write cycles.                                                        |
| 16. Pin 7                                                                               | 65C802 = SYNC.<br>65C816 = VPA                                                                                              | SYNC                                                                               | SYNC                                                                                                        |
| 17. COP Instruction<br>Signatures 00-7F user defined<br>Signatures 80-FF reserved       | Available                                                                                                                   | Not available                                                                      | Not available                                                                                               |

## **TABLE 2. INSTRUCTION SET – ALPHABETICAL SEQUENCE**

| ADC  | Add Memory to Accumulator with Carry                        |
|------|-------------------------------------------------------------|
| AND  | "AND" Memory with Accumulator                               |
| ASL  | Shift One Bit Left, Memory or Accumulator                   |
| BCC  | Branch on Carry Clear ( $P_{C} = 0$ )                       |
| BCS  | Branch on Carry Set ( $Pc = 1$ )                            |
| BEO  | Branch if Equal (Pz = 1)                                    |
| DIT  | Dianch il Equal (FZ - 1)                                    |
|      | Dit fest<br>Brench if Deput Minut (Du = 1)                  |
|      | Branch II Result Minus (PN = 1)                             |
| BNE  | Branch if Not Equal (PZ = 0)                                |
| BPL  | Branch If Result Plus (PN = 0)                              |
| BRA  | Branch Always                                               |
| BRK  | Force Break                                                 |
| BRL  | Branch Always Long                                          |
| BVC  | Branch on Overflow Clear (Pv = 0)                           |
| BVS  | Branch on Overflow Set (Pv = 1)                             |
| CLC  | Clear Carry Flag                                            |
| CLD  | Clear Decimal Mode                                          |
| CLI  | Clear Interrupt Disable Bit                                 |
| CLV  | Clear Overflow Flag                                         |
| CMP  | Compare Memory and Accumulator                              |
| COP  | Coprocessor                                                 |
| CPX  | Compare Memory and Index X                                  |
| CPY  | Compare Memory and Index X                                  |
| DEC  | Decrement Memory or Accumulator by One                      |
| DEY  | Decrement Index X by One                                    |
|      | Decrement Index X by One                                    |
| EOD  | "Evolution OD" Memory with Assumption                       |
| EUR  | Exclusive OR Memory with Accumulator                        |
| INC  | increment memory or Accumulator by One                      |
| INX  | Increment Index X by One                                    |
| INY  | Increment Index Y by One                                    |
| JML  | Jump Long                                                   |
| JMP  | Jump to New Location                                        |
| JSL  | Jump Subroutine Long                                        |
| JSR  | Jump to New Location Saving Return Address                  |
| LDA  | Load Accumulator with Memory                                |
| LDX  | Load Index X with Memory                                    |
| LDY  | Load Index Y with Memory                                    |
| LSR  | Shift One Bit Right (Memory or Accumulator)                 |
| MVN  | Block Move Negative                                         |
| MVP  | Block Move Positive                                         |
| NOP  | No Operation                                                |
| ORA  | "OB" Memory with Accumulator                                |
| PEA  | Push Effective Absolute Address on Stack (or Push Immediate |
|      | Data on Stack)                                              |
| DEI  | Buch Effective Indirect Address on Steels (or Dist.)        |
| . 21 | Push Enecuve Indirect Address on Stack (or Push Direct      |
| DED  | Data on Stack)                                              |
| PER  | Push Effective Program Counter Relative Address on Stack    |
|      |                                                             |

PHA Push Accumulator on Stack PHB Push Data Bank Register on Stack PHD Push Direct Register on Stack PHK Push Program Bank Register on Stack PHP Push Processor Status on Stack PHX Push Index X on Stack PHY Push Index Y on Stack PLA Pull Accumulator from Stack PLB Pull Data Bank Register from Stack PLD Pull Direct Register from Stack PLP Pull Processor Status from Stack PLX Pull Index X from Stack PLY Pull Index Y form Stack REP **Reset Status Bits** ROL Rotate One Bit Left (Memory or Accumulator) ROR Rotate One Bit Right (Memory or Accumulator) RTI Return from Interrupt RTL Return from Subroutine Long RTS Return from Subroutine Subtract Memory from Accumulator with Borrow SBC SEC Set Carry Flag SED Set Decimal Mode SEI Set Interrupt Disable Status SEP Set Processor Status Bite STA Store Accumulator in Memory STP Stop the Clock STX Store Index X in Memory Store Index Y in Memory STY STZ Store Zero in Memory TAX Transfer Accumulator to Index X TAY Transfer Accumulator to Index Y TCD Transfer C Accumulator to Direct Register TCS Transfer C Accumulator to Stack Pointer Register TDC Transfer Direct Register to C Accumulator TRB Test and Reset Bit TSB Test and Set Bit TSC Transfer Stack Pointer Register to C Accumulator Transfer Stack Pointer Register to Index X TSX TXA Transfer Index X to Accumulator TXS Transfer Index X to Stack Pointer Register TXY Transfer Index X to Index Y TYA Transfer Index Y to Accumulator TYX Transfer Index Y to Index X WAI Wait for Interrupt WDM Reserved for Future Use XBA Exchange B and A Accumulator XCE Exchange Carry and Emulation Bits

For alternate mnemonics, see Table 7.

## **TABLE 3. VECTOR LOCATIONS**

| E = 1                |                   | E = 0               |          |
|----------------------|-------------------|---------------------|----------|
| OOFFFE.F             | Hardware/Software | OOFFEE.F IRQ        | Hardware |
| OOFFFC,D-RESET       | Hardware          | OOFFEC.D-(Reserved) |          |
| OOFFFA,B NMI         | Hardware          | OOFFEA,B-NMI        | Hardware |
| OOFFF8,9 -ABORT      | Hardware          | OOFFE8,9 -ABORT     | Hardware |
| OOFFF6,7 —(Reserved) |                   | OOFFE6,7 -BRK       | Software |
| OOFFF4,5 —COP        | Software          | OOFFE4,5 -COP       | Software |
|                      |                   |                     |          |

The VP output is low during the two cycles used for vector location access. When an interrupt is executed, D = 0 and I = 1 in Status Register P.



## TABLE 4. OPCODE MATRIX

| м      |                           |                  |                        |                             |                             |                |                |                           |              |                |                           |                          |                           |                |                  |                          | м      |
|--------|---------------------------|------------------|------------------------|-----------------------------|-----------------------------|----------------|----------------|---------------------------|--------------|----------------|---------------------------|--------------------------|---------------------------|----------------|------------------|--------------------------|--------|
| S<br>D |                           |                  |                        |                             |                             |                |                | LSD                       |              |                |                           |                          |                           |                |                  |                          | S<br>D |
|        | 0                         | 1                | 2                      | 3                           | 4                           | 5              | 6              | 7                         | 8            | 9              | A                         | в                        | с                         | D              | E                | F                        |        |
| 0      | BRKs<br>28                | ORA (d,x)<br>2 6 | COP s<br>2 * 8         | ORA d,s<br>2 * 4            | TSB d<br>2 • 5              | ORAd<br>23     | ASL d<br>2 5   | ORA [d]<br>2 * 6          | PHP s<br>1 3 | ORA #<br>2 2   | ASL A<br>1 2              | PHD s<br>1 <b>*</b> 4    | TSB a<br>3 <sup>•</sup> 6 | ORA a<br>3 4   | ASLa<br>36       | ORA al<br>4 * 5          | 0      |
| 1      | BPL r<br>2 2              | ORA (d),y<br>2 5 | ORA (d)<br>2 • 5       | ORA (d.s),y                 | TRB d                       | ORA d,x<br>2 4 | ASL d,x<br>2 6 | ORA [d],y<br>2 6          | CLC i        | ORA a,y        |                           | TCS i<br>1 * 2           | TRB a<br>3 6              | ORA a,x<br>3 4 | ASLa,x<br>37     | ORA al,x<br>4 <b>*</b> 5 | 1      |
| 2      | JSR a<br>3 6              | AND (d,x)<br>2 6 | JSL al<br>4 <b>*</b> 8 | AND d,s<br>2 * 4            | BIT d<br>2 3                | AND d<br>2 3   | ROLd<br>25     | AND [d]<br>2 * 6          | PLPs<br>14   | AND #<br>2 2   | ROL A<br>1 2              | PLD s<br>1 <b>*</b> 5    | BITa<br>34                | AND a<br>3 4   | ROLa<br>36       | AND al<br>4 <b>*</b> 5   | 2      |
| 3      | BMIr<br>22                | AND (d),y<br>2 5 | AND (d)<br>2 • 5       | AND (d,s),y<br>2 <b>*</b> 7 | BIT d,x<br>2 <sup>•</sup> 4 | AND d,x<br>2 4 | ROL d,x<br>2 6 | AND [d],y<br>2 * 6        | SEC i<br>1 2 | AND a,y<br>3 4 | DEC A                     | TSC i<br>1 * 2           | BIT a,x<br>3 • 4          | AND a,x<br>3 4 | ROL a,x<br>3 7   | AND al,x<br>4 <b>*</b> 5 | 3      |
| 4      | RTIs<br>17                | EOR (d,x)<br>2 6 | WDM<br>2 * 2           | EOR d,s<br>2 * 4            | MVP xyc<br>3 * 7            | EOR d<br>2 3   | LSRd<br>25     | EOR [d]<br>2 * 6          | PHA s<br>1 3 | EOR #<br>2 2   | LSR A<br>1 2              | PHK s<br>1 <b>*</b> 3    | JMPa<br>33                | EOR a<br>34    | LSRa<br>36       | EOR al<br>4 * 5          | 4      |
| 5      | BVCr<br>22                | EOR (d),y<br>2 5 | EOR (d)<br>2 • 5       | EOR (d,s),y<br>2 * 7        | MVN xyc<br>3 * 7            | EOR d,x<br>2 4 | LSR d,x<br>2 6 | EOR [d],y<br>2 <b>*</b> 6 | CLI i<br>1 2 | EOR a,y<br>3 4 | PHY s<br>1 • 3            | TCD i<br>1 <b>*</b> 2    | JMP al<br>4 <b>*</b> 4    | EOR a,x<br>3 4 | LSR a,x<br>3 7   | EOR al,x<br>4 * 5        | 5      |
| 6      | RTSs<br>16                | ADC (d,x)<br>2 6 | PER s<br>3 * 6         | ADC d,s<br>2 * 4            | STZ d<br>2•3                | ADC d<br>2 3   | ROR d<br>2 5   | ADC [d]<br>2 * 6          | PLA s<br>1 4 | ADC #<br>2 2   | ROR A<br>1 2              | RTL s<br>1 * 6           | JMP (a)<br>3 5            | ADC a<br>3 4   | ROR a<br>3 6     | ADC al<br>4 * 5          | 6      |
| 7      | BVSr<br>22                | ADC (d),y<br>2 5 | ADC (d)<br>2 • 5       | ADC (d,s),y<br>2 * 7        | STZ d,x<br>2 4              | ADC d,x<br>2 4 | ROR d,x<br>2 6 | ADC [d],y<br>2 * 6        | SELI<br>1 2  | ADC a,y<br>3 4 | PLY s<br>1 • 4            | TDC i<br>1 <b>*</b> 2    | JMP (a,x)<br>3 • 6        | ADC a,x<br>3 4 | ROR a,x<br>3 7   | ADC al,x<br>4 <b>*</b> 5 | 7      |
| 8      | BRA r<br>2 <sup>•</sup> 2 | STA (d.x)<br>2 6 | BRL rl<br>3 * 3        | STA d,s<br>2 * 4            | STY d<br>2 3                | STAd<br>23     | STX d<br>2 3   | STA [d]<br>2 * 6          | DEY i<br>1 2 | BIT #<br>2 • 2 | TXA i<br>1 2              | PHB s<br>1 <b>*</b> 3    | STYa<br>34                | STA a<br>3 4   | STXa<br>34       | STA al<br>4 * 5          | 8      |
| 9      | BCC r<br>2 2              | STA (d),y<br>2 6 | STA (d)<br>2 • 5       | STA (d,s),y<br>2 * 7        | STY d,x<br>2 4              | STA d,x<br>2 4 | STX d,y<br>2 4 | STA [d],y<br>2 * 6        | TYA i<br>12  | STA a,y<br>3 5 | TXS i<br>1 2              | TXY i<br>1 * 2           | STZ a<br>3 <sup>•</sup> 4 | STA a,x<br>3 5 | STZ a,x<br>3 • 5 | STA al,x<br>4 * 5        | 9      |
| A      | LDY #<br>2 2              | LDA (d,x)<br>2 6 | LDX #<br>2 2           | LDA d,s<br>2 * 4            | LDY d<br>2 3                | LDA d<br>2 3   | LDX d<br>2 3   | LDA [d]<br>2 * 6          | TAY i<br>1 2 | LDA #<br>2 2   | TAX i<br>1 2              | PLB s<br>1 <b>*</b> 4    | LDYa<br>34                | LDA a<br>34    | LDXa<br>34       | LDA al<br>4 <b>*</b> 5   | А      |
| в      | BCSr<br>22                | LDA (d),y<br>2 5 | LDA (d)<br>2 • 5       | LDA (d,s),y<br>2 <b>*</b> 7 | LDY d,x<br>2 4              | LDA d,x<br>2 4 | LDX d,y<br>2 4 | LDA [d],y<br>2 <b>*</b> 6 | CLV i<br>1 2 | LDA a,y<br>3 4 | TSX i<br>1 2              | TYX i<br>1 * 2           | LDY a,x<br>3 4            | LDA a,x<br>3 4 | LDX a,y<br>3 4   | LDA al,x<br>4 <b>*</b> 5 | в      |
| С      | CPY #<br>2 2              | CMP (d,x)<br>2 6 | REP #<br>2 <b>*</b> 3  | CMP d,s<br>2 * 4            | CPY d<br>2 3                | CMPd<br>23     | DEC d<br>2 5   | CMP [d]<br>2 * 6          | INY i<br>1 2 | CMP #<br>2 2   | DEX i<br>1 2              | WALI<br>1 <sup>●</sup> 3 | CPY a<br>3 4              | CMPa<br>34     | DECa<br>36       | CMP al<br>4 <b>*</b> 5   | с      |
| D      | BNEr<br>22                | CMP (d),y<br>2 5 | CMP (d)<br>2 • 5       | CMP (d,s),y<br>2 <b>*</b> 7 | PEIS<br>2 <b>*</b> 6        | CMP d,x<br>2 4 | DEC d,x<br>2 6 | CMP [d],y<br>2 <b>*</b> 6 | CLD i<br>1 2 | CMP a,y<br>3 4 | PHX s<br>1 <sup>●</sup> 3 | STP i<br>1 • 3           | JML (a)<br>3 <b>*</b> 6   | CMP a,x<br>3 4 | DEC a,x<br>3 7   | CMP al,x<br>4 <b>*</b> 5 | D      |
| E      | CPX #<br>2 2              | SBC (d,x)<br>2 6 | SEP #<br>2*3           | SBC d,s<br>2 * 4            | CPX d<br>2 3                | SBC d<br>2 3   | INC d<br>2 5   | SBC [d]<br>2 * 6          | INX i<br>1 2 | SBC #<br>2 2   | NOP i<br>1 2              | XBA i<br>1 <b>*</b> 3    | CPXa<br>34                | SBCa<br>34     | INC a<br>36      | SBC al<br>4 * 5          | E      |
| F      | BEQ r<br>2 2              | SBC (d),y<br>2 5 | SBC (d)<br>2 • 5       | SBC (d,s),y<br>2 * 7        | PEA s<br>3 * 5              | SBC d,x<br>2 4 | INC d,x<br>2 6 | SBC [d],y<br>2 <b>*</b> 6 | SED i<br>1 2 | SBC a,y<br>3 4 | PLX s<br>1 • 4            | XCE i<br>1 <b>*</b> 2    | JSR (a,x)<br>3 * 6        | SBC a,x<br>3 4 | INC a,x<br>3 7   | SBC al,x<br>4 * 5        | F      |
|        | 0                         | 1                | 2                      | 3                           | 4                           | 5              | 6              | 7                         | 8            | 9              | A                         | в                        | с                         | D              | E                | F                        |        |

| symbol | addressing mode               | symbol  | addressing mode                 |
|--------|-------------------------------|---------|---------------------------------|
| #      | immediate                     | [d]     | direct indirect long            |
| А      | accumulator                   | [d],y   | direct indirect long indexed    |
| r      | program counter relative      | a       | absolute                        |
| rl     | program counter relative long | a,x     | absolute indexed (with x)       |
| i      | implied                       | a,y     | absolute indexed (with y)       |
| s      | stack                         | al      | absolute long                   |
| d      | direct                        | al,x    | absolute long indexed           |
| d,x    | direct indexed (with x)       | d,s     | stack relative                  |
| d,y    | direct indexed (with y)       | (d,s),y | stack relative indirect indexed |
| (d)    | direct indirect               | (a)     | absolute indirect               |
| (d,x)  | direct indexed indirect       | (a,x)   | absolute indexed indirect       |
| (d),y  | direct indirect indexed       | хус     | block move                      |

## **Op Code Matrix Legend**

| INSTRUCTION<br>MNEMONIC | <b>*</b> = New .65C816/802 Opcodes | ADDRESSING<br>MODE |
|-------------------------|------------------------------------|--------------------|
| BASE                    | • = New 65C02 Opcodes              | BASE               |
| NO. BYTES               | Blank = NMOS 6502 Opcodes          | NO. CYCLES         |

|            | TABLE 5                                                                                          | Γ        | Γ        |          | <b></b>  |          |          |          |          |          |          | [   |          | T        |          |            |    |      |          |          |       |          |                         | ž        |           | 1              | Pf<br>ST                |            | ESS<br>IS C | OD       |               |       | MNE-       |
|------------|--------------------------------------------------------------------------------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|-----|----------|----------|----------|------------|----|------|----------|----------|-------|----------|-------------------------|----------|-----------|----------------|-------------------------|------------|-------------|----------|---------------|-------|------------|
|            |                                                                                                  | #        |          | Te       | σ        | •        | -        | (d),     | Ę        | (x,b)    | ÷        | Å,  | a,x      | al,x     | a,y      | 2          | τ  | (e)  | Ð        | Ξ        | (a,x) | 60       | d,s                     | (d,s)    | xyc       | 7 <sup>•</sup> | 6 5<br>V N              | 54         | 3<br>D      | 2        | 1 C           |       |            |
|            | OPERATION                                                                                        | 1        | 2        | 3        | 4        | 5        | 6        | 7        | 8        | 9        | 10       | 11  | 12       | 13       | 14       | 15         | 16 | 17   | 18       | 19       | 20    | 21       | 22                      | 23       | 24        | N              | v                       | 1 8        | D           | ÷        | ZC            | ; E = | 1          |
| ADC<br>AND | $A + M + C \rightarrow A$<br>AAM $\rightarrow A$                                                 | 69<br>29 | 6D<br>2D | 6F<br>2F | 65<br>25 |          | 1        | 71<br>31 | 77<br>37 | 61<br>21 | 75<br>35 |     | 7D<br>3D | 7F<br>3F | 79<br>39 |            |    |      | 72<br>32 | 67<br>27 |       |          | 63<br>23                | 73<br>33 |           | N<br>N         | v                       | · ' .      | ÷           | 1        | z c           |       | ADC        |
| ASL<br>BCC | C - [15/7 0] - 0<br>BRANCH IF C = 0                                                              |          | 0E       | ÷.,.     | 06       | 0A       |          |          |          |          | 16       |     | 1E       |          |          | 90         |    |      |          |          |       |          |                         |          |           | N              | : :                     |            | 1           | :        | z c           | 1     | ASL<br>BCC |
| BCS        | BRANCH IF C = 1                                                                                  | -        | -        |          | -        | -        |          |          |          |          | -        | -   | -        | -        |          | B0<br>F0   | -  |      |          |          |       |          |                         |          |           |                |                         |            |             | ÷        |               | +     | BCS        |
| BIT        | AAM (NOTE 1)<br>BRANCH IF N = 1                                                                  | 89       | 2C       |          | 24       | 1.       |          |          |          |          | 34       |     | 3C       |          |          | 30         |    | 1. A |          |          |       |          | $\mathcal{A}_{n}^{(i)}$ |          | ٩.        | M, I           | Me                      |            |             | ÷        | ż.            |       | BIT        |
| BNE<br>BPL | BRANCH IF Z = 0<br>BRANCH IF N = 0                                                               |          |          | 81 L     | 1.       |          |          |          |          |          |          |     | 1        |          |          | D0<br>10   |    |      |          |          |       |          |                         |          |           | :              | :                       |            | ÷           | 1        |               | 1     | BNE<br>BPL |
| BRA        | BRANCH ALWAYS                                                                                    |          |          |          |          |          |          |          |          |          |          |     |          |          |          | 80         |    |      | 1        |          |       | 00       |                         |          | 1         | • .            | •                       |            | i           |          | • •           | •     | BRA        |
| BRL        | BRANCH LONG ALWAYS                                                                               | ۴.       | 1        |          |          |          |          |          |          |          |          |     |          |          |          | 50         | 82 |      |          |          |       |          |                         | 4        |           | ŀ.             |                         |            |             |          |               | *     | BRL        |
| BVS        | BRANCH IF V = 1                                                                                  |          |          |          |          |          | 10       |          |          |          | -        |     | -        |          |          | 70         | -  | -    |          |          |       |          |                         |          |           | -              |                         |            |             |          |               | _     | BVS        |
| CLD        | 0-C<br>0-D                                                                                       |          |          | 1        | 1        |          | D8       |          |          |          |          |     |          |          |          |            |    |      |          |          |       |          |                         |          |           | 2              | 40 - 10<br>- 10<br>- 10 |            | ò           | à        |               | 1     | CLD        |
| CLV        |                                                                                                  | C9       | СП       | CF       | C5       |          | B8       | D1       | D7       | C1       | D5       |     |          | DF       | D9       |            |    |      | D2       | C7       |       |          | СЗ                      | D3       |           | N              | Ó.                      |            |             | ÷        | żċ            |       | CLV<br>CMP |
| COP        | CO-PROCESSOR                                                                                     | 50       | 50       |          |          |          |          |          |          |          |          |     | -        |          |          |            |    | 1    |          |          |       | 02       |                         |          |           | Ň              |                         |            | 0           | 1        | ÷ ;           | *     | COP        |
| CPY        |                                                                                                  | Ē0       | CC       |          | C4       | 34       |          |          |          |          | De       |     | DE       |          |          |            |    | 1    |          |          |       |          |                         |          |           | NN             | • •                     |            | :           | :        | $\frac{2}{7}$ |       | CPY        |
| DEX        | $X - 1 \rightarrow X$                                                                            |          |          |          |          |          | CA       |          |          |          |          |     | -        |          |          |            | ļ  |      |          |          | -     |          |                         |          |           | N              |                         |            |             |          | ž .           | 1     | DEX        |
| DEY<br>EOR | $Y - 1 \rightarrow Y$<br>AVM $\rightarrow A$                                                     | 49       | 4D       | 4F       | 45       |          | 88       | 51       | 57       | 41       | 55       |     | 5D       | 5F       | 59       |            |    |      | 52       | 47       |       |          | 43                      | 53       |           | N              |                         |            | :           | :        | Z .           |       | EOR        |
| INC        |                                                                                                  |          |          | 4 у.     | EO       |          | E8       |          |          |          | 10       |     |          |          | - 14     | 1.12       |    |      |          |          |       |          |                         |          |           | N              |                         |            | :           | :        | Z .           |       | INX        |
| JML        | JUMP LONG TO NEW LOC.                                                                            |          |          |          |          |          | 00       | 11       | 1        | · · ·    | -        |     |          | 1.       |          | -          | +  | DC   |          |          |       |          |                         | -        |           |                |                         | · ·        |             | ÷        |               | *     | JML        |
| JMP<br>JSL | JUMP TO NEW LOC.<br>JUMP LONG TO SUB.                                                            | Ľ,       | 4C       | 5C<br>22 | 4        |          |          |          |          | 4        |          |     |          |          |          |            |    | 6C   |          |          | 70    |          |                         |          |           | •              | :                       | <br>       | 1           | :        | · ·           |       | JMP<br>JSL |
| LDA        | JUMP TO SUB.<br>M → A                                                                            | A9       | AD       | AF       | A5       |          |          | B1       | B7       | A1       | B5       |     | вD       | BF       | В9       |            |    |      | B2       | A7       | r.    | A3       | В3                      |          |           | Ň              |                         | · ·        |             | :        | ż             |       | LDA        |
| LDX<br>LDY | M → X<br>M → Y                                                                                   | A2<br>A0 | AE<br>AC |          | A6<br>A4 |          |          | 1        |          |          | В4       | B6  | вс       |          | BE       |            |    |      |          |          |       |          |                         |          | 1913)<br> | NN             |                         | : :        |             | Ċ,       | Z .<br>Z .    |       | LDX        |
| LSR<br>MVN | 0 – <u>15/7</u> 0 – C<br>M – M BACKWARD                                                          |          | 4E       |          | 46       | 4A       |          | 1        |          |          | 56       |     | 5E       |          |          |            |    |      |          |          |       |          |                         |          | 54        | 0              | •                       | .~:        |             |          | z c           | *     | MVN        |
| NOP        | NO OPERATION                                                                                     |          | 1.1      | 1        |          |          | EA       |          |          | 1        |          |     |          | +        |          |            |    |      | -        |          |       |          |                         |          | 44        |                |                         | <u> </u>   |             |          | <u>.</u>      | +     | NOP        |
| ORA<br>PEA | AVM → A<br>Mpc + 1, Mpc + 2 → Ms - 1, Ms                                                         | 09       | 0D       | OF       | 05       |          |          | 11       | 17       | 01       | 15       |     | 1D       | 1F       | 19       | ан н.<br>С |    |      | 12       | 07       |       | F4       | 03                      | 13       |           | N<br>          |                         | i, i<br>F  |             | ÷        | Z .           | *     | ORA<br>PEA |
| PEI        | S - 2 → S<br>M(d), M(d + 1) → Ms - 1, Ms                                                         |          | e, *1    |          |          |          |          |          |          |          | -        | 2.  |          |          |          |            | 1. |      | Č.       | н.<br>Т. |       | D4       | -                       |          |           |                | •                       | i, i       |             |          |               | *     | PEI        |
| PER        | $S - 2 \rightarrow S$<br>Mpc + rl, Mpc + rl + 1 $\rightarrow$ Ms - 1, Ms                         |          |          |          |          |          |          |          |          |          | 2        |     |          |          |          |            |    |      |          |          |       | 62       |                         |          |           | •              |                         |            |             | ÷.,      |               | *     | PER        |
| PHA        | S-2→S<br>A→Ms, S-1→S                                                                             | -        | -        |          | -        |          | -        |          | -        |          |          |     |          | -        | -        |            |    | -    |          |          | -     | 48       | 0.5                     |          |           | -              | • 1                     |            | · · ·       |          |               | +     | PHA        |
| PHB<br>PHD | DBR → Ms, S - 1 → S<br>D → Ms, Ms - 1, S - 2 → S                                                 | . i.     |          |          |          |          |          |          |          |          |          | 1   |          |          |          |            |    |      |          |          |       | 0B       |                         |          | , *       |                | i.                      |            | s į         | 1        | ÷.            | *     | PHB        |
| PHK<br>PHP | $PBR \rightarrow Ms, S - 1 \rightarrow S$ $P \rightarrow Ms, S - 1 \rightarrow S$                | 1        |          |          |          |          |          |          |          |          |          |     |          |          |          |            |    |      |          | 1        |       | 08       |                         | à c      |           |                | 14                      |            |             |          |               | *     | PHK        |
| PHX<br>PHY | $X \rightarrow Ms, S - 1 \rightarrow S$<br>$Y \rightarrow Ms, S - 1 \rightarrow S$               | 1        |          |          |          |          |          |          | 1        |          |          | 1   |          |          |          |            |    |      |          |          | 1     | DA<br>5A |                         |          |           | •              | 1                       |            | :           | 1        | : :           | :     | PHX        |
| PLA<br>PLB | $S + 1 \rightarrow S$ , $Ms \rightarrow A$<br>$S + 1 \rightarrow S$ , $Ms \rightarrow DBR$       |          |          |          |          |          |          |          |          |          |          |     |          |          |          |            |    |      |          |          |       | AB       |                         |          |           | N              |                         |            | :           | 1        | Z.            | *     | PLA<br>PLB |
| PLD        | $S + 2 \rightarrow S$ , Ms - 1, Ms $\rightarrow D$<br>S + 1 $\rightarrow S$ , Ms $\rightarrow P$ |          | 1        |          | -        |          |          |          | 2        |          |          |     |          |          |          |            | -  |      | - N.     | -        |       | 28       |                         |          |           | N              | V N                     | <br>И Х    | D           | ÷        | Z .           | *     | PLD        |
| PLX        | S + 1 - S, $Ms - XS + 1 - S$ , $Ms - Y$                                                          |          |          |          |          |          |          | 14       | 1        |          |          |     |          |          |          |            |    |      |          |          |       | FA<br>7A |                         |          |           | N<br>N         |                         |            |             | ÷        | ż             |       | PLX        |
| REP        |                                                                                                  | C2       | 2E       |          | 26       | 2A       | 1.1      |          |          |          | 36       |     | 3E       |          |          |            |    |      |          |          |       |          |                         |          |           | N<br>N         | VN                      | νх         | D           | 1        | ZC            | *     | REP        |
| BOB        |                                                                                                  |          | 6E       |          | 66       | 6A       |          |          | -        | - 57     | 76       |     | 7E       | 1        |          |            |    |      |          |          |       |          | -                       |          |           | N              |                         |            |             | <u> </u> | zo            |       | ROR        |
| RTI<br>RTL | RTRN FROM INT.<br>RTRN FROM SUB. LONG                                                            |          |          |          |          |          |          |          |          |          |          |     |          |          |          |            |    |      |          |          |       | 40<br>6B |                         |          |           | N              | V N                     | их<br>     | D           | 1        | z (           | *     | RTI        |
| RTS<br>SBC | RTRN SUBROUTINE<br>A - M - $\overrightarrow{C} \rightarrow A$                                    | E9       | ED       | EF       | E5       |          |          | F1       | F7       | E1       | F5       |     | FD       | FF       | F9       | 100        |    |      | F2       | E7       |       | 60       | E3                      | F3       |           | Ň              | ý -                     |            |             |          | żċ            | :     | RTS<br>SBC |
| SEC<br>SED | 1 → C<br>1 → D                                                                                   |          |          |          |          |          | 38<br>F8 |          |          |          |          |     |          |          |          | 1.         |    |      |          |          |       |          |                         |          |           |                | :                       | : :        | i           | 3        | : 1           |       | SEC<br>SED |
| SEI<br>SEP | 1 → I<br>MVP → P                                                                                 | E2       |          |          |          |          | 78       |          |          |          |          |     |          |          |          |            |    |      |          |          |       |          |                         |          |           | Ň              | ý. M                    | ù x        | Ď           | 1        | żċ            | *     | SEI<br>SEP |
| STA        | $A \rightarrow M$<br>STOP (1 $\rightarrow d2$ )                                                  |          | 8D       | 8F       | 85       | -        | DB       | 91       | 97       | 81       | 95       |     | 9D       | 9F       | 99       |            |    | -    | 92       | 87       |       |          | 83                      | 93       |           |                |                         |            |             | <u> </u> | <u></u>       |       | STA        |
| STX<br>STY | $X \rightarrow M$<br>$Y \rightarrow M$                                                           |          | 8E<br>8C |          | 86<br>84 |          |          |          |          |          | 94       | 96  |          |          |          |            |    |      |          |          |       |          | ÷.,                     |          |           |                |                         |            |             |          | •             |       | STX<br>STY |
| STZ<br>TAX | $00 \rightarrow M$<br>A $\rightarrow X$                                                          |          | 90       |          | 64       |          | AA       |          |          |          | 74       | 14  | 9E       |          |          |            | Ι. | 1    |          |          |       |          |                         |          |           | Ň              | •                       | : :        |             | :,       | ż             | •     | STZ<br>TAX |
| TAY<br>TCD |                                                                                                  |          |          |          |          |          | A8<br>5B |          |          |          |          | 1.1 |          | 4        |          |            |    |      |          | 1        |       |          |                         |          |           | NN             | ÷                       |            |             | -        | Z<br>Z        | *     | TAY<br>TCD |
| TCS<br>TDC | $\tilde{C} \rightarrow \tilde{S}$<br>$D \rightarrow C$                                           |          |          |          |          |          | 1B<br>7B | 1        |          |          |          |     |          |          |          |            |    |      |          |          |       |          |                         |          |           | Ň              | :                       |            | ÷           | :        | ż             | *     | TCS<br>TDC |
| TRB        | AVM → M                                                                                          |          | 10       |          | 14       | 1        |          |          | -        |          |          | -   | -        |          |          |            | -  | -    |          |          |       |          |                         |          | <u> </u>  | :              | ÷                       | <u>· ·</u> | . ·         |          | Z.            | •     | TRB        |
| TSC<br>TSX | S→C<br>S→X                                                                                       |          |          |          | ľ        | 3B<br>BA | a<br>are |          |          |          |          |     |          | ۰.       |          |            |    |      |          |          |       |          |                         |          |           | NN             | ÷                       |            | ÷           | ÷        | z .           | *     | TSC<br>TSX |
| TXA<br>TXS | $\begin{array}{c} X \to A \\ X \to S \end{array}$                                                | 1        |          |          |          | 8A<br>9A |          |          |          |          |          | 1   |          |          |          |            |    | 1    |          |          |       |          |                         |          |           | N              | :                       |            | :           |          | Z             |       | TXA<br>TXS |
| TXY        | $X \rightarrow Y$<br>$Y \rightarrow A$                                                           |          |          |          |          | 9B<br>98 |          |          |          |          |          |     |          |          |          |            | 1  | 1.1  | 1        |          | - 22  |          |                         | 1        |           | NN             | ÷                       |            |             | :        | Z.            | *     | TXY<br>TYA |
| TYX<br>WAI | $Y \rightarrow X$<br>0 $\rightarrow RDY$                                                         |          |          |          |          | BB<br>CB |          | 1        |          |          | 1        |     |          |          |          |            |    |      |          | 1        |       |          |                         |          | 21        | N              | ÷                       | : :        | ÷           | :        | Ž.            |       | TYX<br>WAI |
|            |                                                                                                  | -        |          |          | -        | 42<br>EP | -        |          | 1        |          | -        |     |          | -        |          |            | -  |      |          |          |       |          | -                       |          | -         | N              | •                       | <u>· ·</u> |             | ÷        | <br>Z         | *     | WDM<br>XRA |
| XČE        | č→Ê                                                                                              |          |          |          |          | FB       |          |          | 1.1      |          |          |     |          |          |          |            |    |      |          |          |       |          |                         |          |           | 1              | :                       |            |             |          | Ξ. Ε          | *     | XCE        |

## TABLE 6. DETAILED INSTRUCTION OPERATION

|              | ADDRESS MODE                               | c     | YCLE      | VP, | ML, | VDA,  | VPA | ADDRESS BUS          | DATA BUS              | R/W |       | ADDRESS MODE                                |     | YCLE      | VP, | ML, | VDA, | VPA  | ADDRESS BUS               | DATA BUS              | R/W |
|--------------|--------------------------------------------|-------|-----------|-----|-----|-------|-----|----------------------|-----------------------|-----|-------|---------------------------------------------|-----|-----------|-----|-----|------|------|---------------------------|-----------------------|-----|
| 1.           | immediate #                                |       | 1.        | 1   | 1   | 1     | 1   | PBR,PC               | Op Code               | 1   | • 6c. | Wait For Interrupt                          |     |           |     |     |      |      |                           |                       |     |
|              | (LDY, CPY, CPX, LDX, ORA,                  |       | 2.        | 1   | 1   | 0     | 1   | PBR,PC+1             | IDL                   | 1   |       | (WAI)<br>(1 Op Code)                        | (9) | 1.<br>2.  | 1   | 1   | 0    | 1    | 1 PBR,PC<br>1 PBR,PC+1    | Op Code               | 1   |
|              | CMP,SBC REP,SEP)                           | "     | 28.       | '   |     | U     | '   | F00,F012             | 1011                  |     |       | (1 byte)                                    |     | 3.        | 1   | 1   | 0    | Ō    | 0 PBR,PC+1                | ю                     | 1   |
|              | (14 Op Codes)                              |       |           |     |     |       |     |                      |                       |     | . 64  | (3 cycles) IRQ,N                            | łMi | 1.        | 1   | 1   | 1    | 1    | 1 PBR,PC+1                | IRQ(BRK)              | 1   |
|              | (2 and 3 cycles)                           |       |           |     |     |       |     |                      |                       |     | • 60. | (STP)                                       |     | 1.        | 1   | 1   | 1    | 1    | 1 PBR,PC                  | Op Code               | 1   |
| 2a.          | Absolute a                                 |       | 1.        | 1   | 1   | 1     | 1   | PBR,PC               | Op Code               | 1   |       | (1 Op Code)                                 | 5   | 2.        | 1   | 1   | 0    | 0    | 1 PBR,PC+1                | 10                    | 1   |
|              | (BIT,STY,STZ,LDY,                          |       | 2.<br>3   | 1   | 1   | 0<br> | 1   | PBR.PC+1<br>PBR.PC+2 | AAL                   | -   |       | (3 cycles) RES                              | 5=0 | 3.<br>1C. | ÷   | i   | Ű    | 0    | 1 PBR,PC+1                | RES(BRK)              | 1   |
|              | ORA, AND, EOR, ADC,                        |       | 4.        | 1   | 1   | 1     | Ó   | DBR,AA               | Data Low              | 1/0 |       | RES                                         | 5=0 | 1b.       | 1   | 1   | 0    | 0    | 1 PBR,PC+1                | RES(BRK)              | 1   |
|              | STA,LDA,CMP,SBC) (1<br>(18 On Codes)       | I)    | 4a.       | 1   | 1   | 1     | 0   | DBR,AA+1             | Data High             | 1/0 |       | See 21a Stack                               | 3-1 | 1.        | 1   | i.  | 1    | 1    | 1 PBR,PC+1                | BEGIN                 | 1   |
|              | (3 bytes)                                  |       |           |     |     |       |     |                      |                       |     |       | (Hardware interrupt)                        |     |           |     |     |      |      |                           |                       |     |
|              | (4 and 5 cycles)                           |       |           |     |     |       |     |                      |                       |     | -     | Direct Indirect Indexed (d) v               |     |           |     |     | 1    | 1    | PBB PC                    | On Code               | 1   |
| 2b.          | Absolute (R-M-W) a                         |       | 1.        | 1   | 1   | 0     | 1   | PBR.PC+1             | AAL                   | 1   | 7.    | (ORA,AND,EOR,ADC,                           |     | 2.        | i   | i   | ò    | 1    | PBR,PC+1                  | DO                    | i   |
|              | (ASL,ROL,LSR,ROR                           |       | 3.        | 1   | 1   | 0     | 1   | PBR,PC+2             | AAH                   | 1   |       | STA,LDA,CMP,SBC)                            | (2) | 2a.       | 1   | 1   | 0    | 0    | PBR,PC+1                  |                       | 1   |
|              | DEC, INC, TSB, TRB)<br>(6 On Codes) (1     | n     | 4.<br>4a. | 1   | 0   | 1     | 0   | DBR,AA<br>DBR.AA+1   | Data Low<br>Data High | 1   |       | (2 bytes)                                   |     | 4.        | 1   | 1   | i i  | õ    | 0,D+DO+1                  | AAH                   | i   |
|              | (3 bytes) (3                               | 3)    | 5.        | 1   | ō   | Ó     | Ō   | DBR,AA+1             | 10                    | 1   |       | (5,6,7 and 8 cycles)                        | (4) | 4a.       | 1   | 1   | 0    | 0    | DBR, AAH, AAL+            | YL IO<br>Data Low     | 1   |
|              | (6 and 8 cycles) (1                        | 1)    | 6a.<br>6. | 1   | 0   | 1     | 0   | DBR.AA+1<br>DBR.AA   | Data High<br>Data Low | 0   |       |                                             | (1) | 5a.       | i   | i   | i.   | õ    | DBR,AA+Y+1                | Data High             | 1/0 |
| 2c.          | Absolute (JUMP) a                          |       | 1.        | 1   | 1   | 1     | 1   | PBR,PC               | Op Code               | 1   | 8     | Direct Indirect                             |     | 1.        | 1   | 1   | 1    | 1    | PBR,PC                    | Op Code               | 1   |
|              | (JMP)(4C)                                  |       | 2.        | 1   | 1   | 0     | 1   | PBR,PC+1             | NEW PCL               | 1   |       | Indexed Long [d],y                          | (2) | 2.<br>2a  | 1   | 1   | 0    | 1    | PBR,PC+1<br>PBR,PC+1      | 10                    | 1   |
|              | (1 Up Code)<br>(3 bytes)                   |       | 3.<br>1.  | 1   | 1   | 1     | 1   | PBR, NEW PC          | Op Code               | i.  |       | STA,LDA,CMP,SBC)                            | (-) | 3.        | i.  | i.  | 1    | õ    | 0,D+DO                    | AAL                   | 1   |
|              | (3 cycles)                                 |       |           |     |     |       |     |                      |                       |     |       | (8 Op Codes)                                |     | 4.        | 1   | 1   | 1    | 0    | 0,D+DO+1<br>0,D+DO+2      | AAH                   | 1   |
| 24           | Absolute (Jump to                          |       | 1.        | 1   | 1   | 1     | 1   | PBR,PC               | Op Code               | 1   |       | (6,7 and 8 cycles)                          |     | 6.        | i   | i   | i i  | ŏ    | AAB,AA+Y                  | Data Low              | 1/0 |
| 20.          | subroutine) a                              |       | 2.        | 1   | 1   | 0     | 1   | PBR,PC+1             | NEW PCL               | 1   |       |                                             | (1) | 6a.       | 1   | 1   | 1    | 0    | AAB,AA+Y+1                | Data High             | 1/0 |
|              | (JSR)<br>(1 On Code)                       |       | 3.<br>4.  | 1   | 1   | 0     | 0   | PBR,PC+2<br>PBR,PC+2 | IO                    | i   | 9     | ORA.AND.EOR.ADC.                            |     | 1.        | 1   | 1   | 0    | 1    | PBR,PC+1                  | DO                    | 1   |
|              | (3 bytes)                                  |       | 5.        | 1   | 1   | 1     | 0   | 0,S                  | PCH                   | 0   |       | STA, LDA, CMP, SBC)                         | (2) | 2a.       | 1   | 1   | 0    | 0    | PBR,PC+1                  | 10                    | 1   |
|              | (6 cycles)<br>(different order from N6502) |       | 6.<br>1.  | 1   | 1   | 1     | 1   | 0,S-1<br>PBR,NEW PC  | Next Op Code          | 1   |       | (8 Op Codes)<br>(2 bytes)                   |     | 3.<br>4.  | 1   | 1   | 0    | 0    | 0.D+DO+X                  | AAL                   | .1  |
| <b>*</b> 3a. | Absolute Long al                           |       | 1.        | 1   | 1   | 1     | 1   | PBR,PC               | Op Code               | 1   |       | (6,7 and 8 cycles)                          |     | 5.        | 1   | 1   | 1    | Ō    | 0,D+DO+X+1                | AAH                   | 1   |
|              | (ORA,AND,EOR,ADC                           |       | 2.        | 1   | 1   | 0     | 1   | PBR,PC+1             | AAL                   | 1   |       |                                             | (1) | 6.<br>6a  | 1   | 1   | -    | 0    | DBR.AA+1                  | Data Low<br>Data High | 1/0 |
|              | (8 Op Codes)                               |       | 4.        | i   | i   | ŏ     | i   | PBR,PC+3             | AAB                   | i   | 10a   | Direct,X d,x                                | 1.7 | 1.        | - 1 | 1   | 1    | 1    | PBR,PC                    | Op Code               | 1   |
|              | (4 bytes)                                  | 1)    | 5.        | 1   | 1   | 1     | 0   | AAB,AA               | Data Low              | 1/0 |       | (BIT,STZ,STY,LDY,                           | (2) | 2.        | 1   | 1   | 0    | 1    | PBR,PC+1                  | DO                    | 1   |
| <b>*</b> 3h  | Absolute Long (JUMP) al                    | ''    | 1.        | 1   | 1   | 1     | 1   | PBR.PC               | Op Code               | 1   |       | STA,LDA,CMP,SBC)                            | (*) | 3.        | i   | 1   | õ    | ŏ    | PBR,PC+1                  | 10                    | 1   |
|              | (JMP)                                      |       | 2.        | 1   | 1   | 0     | 1   | PBR,PC+1             | NEW PCL               | 1   |       | (11 Op Codes)                               | (1) | 4.<br>49  | 1   | 1   | 1    | 0    | 0,D+DO+X<br>0,D+DO+X+1    | Data Low<br>Data High | 1/0 |
|              | (1 Op Code)<br>(4 bytes)                   |       | 3.<br>4.  | 1   | 1   | 0     | 1   | PBR,PC+2<br>PBR,PC+3 | NEW BR                | i   |       | (4,5 and 6 cycles)                          | (.) | ·u.       |     | ·   |      | •    |                           |                       |     |
|              | (4 cycles)                                 |       | 1.        | 1   | 1   | 1     | 1   | NEW PBR,PC           | Op Code               | 1   | 10b   | Direct,X(R-M-W) d,x                         |     | 1.        | 1   | 1   | 1    | 1    | PBR,PC                    | Op Code               | 1   |
|              |                                            |       |           |     |     |       |     |                      |                       | •   |       | DEC,INC)                                    | (2) | 2.<br>2a. | 1   | 1   | õ    | ò    | PBR,PC+1                  | 10                    | 1   |
| <b>*</b> 3c. | Absolute Long (Jump to                     |       | 1.        | 1   | 1   | 1     | 1   | PBR,PC               | Op Code               | 1   |       | (6 Op Codes)                                |     | 3.        | 1   | 1   | 0    | 0    | PBR,PC+1                  | IO<br>Data Low        | 1   |
|              | Subroutine Long) al                        |       | 2.        | 1   | 1   | 0     | 1   | PBR,PC+1<br>PBR PC+2 | NEW PCL               | 1   |       | (2 bytes)<br>(6,7,8 and 9 cycles)           | (1) | 4.<br>4a. | 1   | õ   | ÷    | ŏ    | 0,D+DO+X+1                | Data High             | i   |
|              | (1 Op Code)                                |       | 4.        | 1   | 1   | 1     | 0   | 0,S                  | PBR                   | 0   |       |                                             | (3) | 5.<br>69  | 1   | 0   | 0    | 0    | 0,D+DO+X+1                | IO<br>Data High       | 1   |
|              | (4 bytes)<br>(7 cycles)                    |       | 5.<br>6.  | 1   | 1   | 0     | 1   | 0.5<br>PBR,PC+3      | NEW PBR               | i   |       |                                             | (1) | 6.        | 1   | õ   | 1    | ŏ    | 0,D+DO+X                  | Data Low              | ō   |
|              |                                            |       | 7.        | 1   | 1   | 1     | 0   | 0,S-1                | PCH                   | 0   | 11    | Direct,Y d,y                                |     | 1.        | 1   | 1   | 1    | 1    | PBR,PC                    | Op Code               | 1   |
|              |                                            |       | o.<br>1.  | 1   | i   | i     | 1   | NEW PBR,PC           | Next Op Code          | 9 1 |       | (STX,LDX)<br>(2 Op Codes)                   | (2) | 2.<br>2a. | 1   | i   | ŏ    | ò    | PBR,PC+1                  | 10                    | 1   |
| 4a.          | Direct d                                   |       | 1.        | 1   | 1   | 1     | 1   | PBR,PC               | Op Code               | 1   |       | (2 bytes)                                   |     | 3.        | 1   | 1   | 0    | 0    | PBR,PC+1                  | IO<br>Data Low        | 1/0 |
|              | (BIT,STZ,STY,LDY,<br>CRY CRY STY LDX (2)   | 21    | 2.<br>2a  | 1   | 1   | 0     | 1   | PBR,PC+1<br>PBR,PC+1 | 10                    | 1   |       | (4,5 and 6 cycles)                          | (1) | 4.<br>4a. | 1   | 1   | 1    | ŏ    | 0,D+DO+Y+1                | Data High             | 1/0 |
|              | ORA, AND, EOR, ADC,                        | -,    | 3.        | 1   | 1   | 1     | 0   | 0,D+DO               | Data Low              | 1/0 | 12a   | Absolute,X a,x                              |     | 1.        | 1   | 1   | 1    | 1    | PBR.PC                    | Op Code               | 1   |
|              | STA,LDA,CMP,SBC) (<br>(18 On Codes)        | 1)    | 3a.       | 1   | 1   | 1     | U   | 0,0+00+1             | Data High             | 1/0 |       | (BIT,LDY,STZ,<br>ORA AND EOR ADC.           |     | 2.        | 1   | 1   | 0    | 1    | PBR,PC+1<br>PBR,PC+2      | AAL                   | 1   |
|              | (2 bytes)                                  |       |           |     |     |       |     |                      |                       |     |       | STA, LDA, CMP, SBC)                         | (4) | 3a.       | 1   | 1   | 0    | 0    | DBR,AAH,AAL+              | XL IO                 | 1   |
| dh           | (3,4 and 5 cycles)<br>Direct (B-M-W) d     |       | 1         | 1   | 1   | 1     | 1   | PBR.PC               | Op Code               | 1   |       | (3 bytes)                                   | (1) | 4a.       | i   | i   | 1    | ŏ    | DBR,AA+X+1                | Data High             | 1/0 |
|              | (ASL,ROL,LSR,ROR                           |       | 2.        | 1   | 1   | 0     | 1   | PBR,PC+1             | DO                    | 1   |       | (4,5 and 6 cycles)                          |     |           |     |     |      |      | 000 00                    | 0-0-4-                |     |
|              | DEC,INC,TSB,TRB) (3<br>(6 On Codes)        | 2)    | 2a.<br>3. | 1   | 0   | 1     | 0   | 0,D+DO               | Data Low              | i   | 126   | Absolute,X(R-M-W) a,x<br>(ASL ROL LSR.ROR.  |     | 1.        | 4   | 1   | 0    | 1    | PBR,PC+1                  | AAL                   | 1   |
|              | (2 bytes) (                                | 1)    | 3a.       | 1   | 0   | 1     | 0   | 0,D+DO+1             | Data High             | 1   |       | DEC,INC)                                    |     | 3.        | 1   | 1   | 0    | 1    | PBR,PC+2                  | AAH                   | 1   |
|              | (5,6,7 and 8 cycles) (                     | 3)    | 4.<br>5a. | 1   | 0   | 1     | 0   | 0,D+DO+1             | Data High             | ò   |       | (6 Op Codes)<br>(3 bytes)                   |     | 4.<br>5.  | 1   | 0   | 1    | 0    | DBR,AAH,AAL+              | Data Low              | 1   |
|              |                                            |       | 5.        | 1   | 0   | 1     | 0   | 0,D+DO               | Data Low              | 0   |       | (7 and 9 cycles)                            | (1) | 5a.       | 1   | 0   | 1    | 0    | DBR,AA+X+1                | Data High             | 1   |
| 5            | Accumulator A<br>(ASL INC ROL DEC.LSR.ROR) | )     | 1.        | 1   | 1   | 1     | 1   | PBR,PC<br>PBR,PC+1   | Op Code<br>IO         | 1   |       |                                             | (1) | 7a.       | 1   | ŏ   | 1    | ŏ    | DBR,AA+X+1                | Data High             | ò   |
|              | (6 Op Codes)                               | ,<br> | - · ·     |     |     |       |     |                      |                       |     |       |                                             |     | 7.        | 1   | 0   | 1    | 0    | DBR,AA+X                  | Data Low              | 0   |
|              | (1 byte)<br>(2 cycles)                     |       |           |     |     |       |     |                      |                       |     | *13   | . Absolute Long X al,x<br>(ORA AND EOR ADC. |     | 1.        | 1   | 1   | 0    | 1    | PBR,PC+1                  | AAL                   | 1   |
| 6a           | Implied I                                  |       | 1.        | 1   | 1   | 1     | 1   | PBR,PC               | Op Code               | 1   |       | STA,LDA,CMP,SBC)                            |     | 3.        | 1   | 1   | 0    | 1    | PBR,PC+2                  | AAH                   | 1   |
|              | (DEY, INY, INX, DEX, NOP,                  |       | 2.        | 1   | 1   | 0     | 0   | PBR,PC+1             | 10                    | 1   |       | (8 Op Codes)<br>(4 bytes)                   |     | 4.<br>5.  | 1   | 1   | 1    | ò    | AAB,AA+X                  | Data Low              | 1/0 |
|              | TAX, TSX, TCS, TSC, TCD,                   |       |           |     |     |       |     |                      |                       |     |       | (5 and 6 cycles)                            | (1) | 5a.       | 1   | 1   | 1    | 0    | AAB,AA+X+1                | Data High             | 1/0 |
|              | TDC, TXY, TYX, CLC, SEC,                   |       |           |     |     |       |     |                      |                       |     | 14    | Absolute, Y a,y                             |     | 1.        | 1   | 1   | 1.   | . 1. | PBR,PC<br>PBR PC+1        | Op Code               | 1   |
|              | (25 Op Codes)                              |       |           |     |     |       |     |                      |                       |     |       | STA,LDA,CMP,SBC)                            |     | 3.        | 1   | 1   | ŏ    | 1    | PBR,PC+2                  | AAH                   | 1   |
|              | (1 byte)<br>(2 cycles)                     |       |           |     |     |       |     |                      |                       |     |       | (9 Op Codes)<br>(3 bytes)                   | (4) | 3a.<br>4. | 1   | 1   | 0    | 0    | DBR,AAH,AAL<br>DBR,AA+Y   | Data Low              | 1/0 |
| <b>*6</b> b  | Implied I                                  |       | 1.        | 1   | 1   | 1     | 1   | PBR,PC               | Op Code               | 1   |       | (4,5 and 6 cycles)                          | (1) | 4a.       | i   | 1   | 1    | ō    | DBR,AA+Y+1                | Data High             | 1/0 |
| 1            | (XBA)                                      |       | 2.        | 1   | 1   | 0     | 0   | PBR,PC+1             | 10                    | 1   | 15    | Relative r                                  |     | 1.        | 1   | 1   | 1    | 1    | PBR,PC<br>PBR,PC+1        | Op Code<br>Offset     | 1   |
|              | (1 byte)                                   |       | э.        |     |     | Ŭ     | Ŭ   |                      |                       |     |       | BCS,BNE,BEQ,BRA)                            | (5) | 2a.       | i   | i   | ŏ    | ò    | PBR,PC+1                  | 10                    | 1   |
|              | (3 cycles)                                 |       |           |     |     |       |     |                      |                       |     |       | (9 Op Codes)<br>(2 bytes)                   | (6) | 2b.<br>1  | 1   | 1   | 0    | 0    | PBR,PC+1<br>PBR,PC+Offeet | IO<br>Op Code         | 1   |
|              |                                            |       |           |     |     |       |     |                      |                       |     |       | (2,3 and 4 cycles)                          |     |           |     |     |      |      |                           |                       |     |

## TABLE 6. DETAILED INSTRUCTION OPERATION (CONT.)

|              | ADDRESS MODE                  | c    | YCLE      | VP, | ML, | VDA,      | VPA   | ADDRESS BUS        | DATA BUS       | R/V      |
|--------------|-------------------------------|------|-----------|-----|-----|-----------|-------|--------------------|----------------|----------|
| <b>*</b> 16. | Relative Long rl              |      | 1         | 1   | 1   | 1         | 1     | PBR,PC             | Op Code        | 1        |
|              | (BRL)                         |      | 2.        | 1   | -1  | 0         | 1     | PBR,PC+1           | Offset Low     | 1        |
|              | (1 Op Code)<br>(3 bytes)      |      | 3.<br>4   | -   | 1   | 0         | 0     | PBB.PC+2           |                | i        |
|              | (4 cycles)                    |      | 1.        | 1   | 1   | - ¥       | ĩ     | PBR,PC+Offset      | Op Code        | ÷ (      |
| 17a.         | Absolute Indirect (a)         |      | 1.        | 1   | 1   | 1         | 1     | PBR,PC             | Op Code        | 1        |
|              | (JMP)                         |      | 2.        | 1   | 1   | 0         | . 1   | PBR,PC+1           | AAL            | 1        |
|              | (1 Op Code)                   |      | 3.        | 1   | 1   | 0         | 1     | PBR,PC+2           | AAH            | 1        |
|              | (5 cycles)                    |      | 5.        | 1   | . 1 | 1         | ŏ     | 0.AA+1             | NEW PCH        | 1        |
|              |                               |      | 1.        | 1   | 1   | <u>_1</u> | - i - | PBR,NEW PC         | Op Code        | 1        |
| 17b.         | Absolute Indirect (a)         |      | 1.        | 1   | 1   | 1         | . 1   | PBR,PC             | Op Code        | 1        |
|              |                               |      | 2.        | 1   | 1   | 0         | 1     | PBR,PC+1           | AAL            | 1        |
|              | (JML)<br>(1 Op Code)          |      | 3.<br>4   | 1   | 1   | 1         | 1     | PBH,PC+2           | AAH<br>NEW PCI | 1        |
|              | (3 bytes)                     |      | 5.        | i   | i   | i.        | ŏ     | 0,AA+1             | NEW PCH        | i        |
|              | (6 cycles)                    |      | 6.        | 1   | . 1 | 1         | 0     | 0,AA+2             | NEW PBR        | 1        |
|              |                               |      | 1.        | 1   | 1   | 1.,       | 1     | NEW PBR,PC         | Op Code        | 1        |
| • 18.        | Direct Indirect (d)           |      | 1.        | 1   | 1   | 1         | 1     | PBR,PC             | Op Code        | 1        |
|              | STA L DA CMP.SBC)             | (2)  | 2.<br>2a. | 1   | i   | ŏ         | 0     | PBR.PC+1           | 10             | ł        |
|              | (8 Op Codes)                  |      | 3.        | 1   | 1   | 1         | ō     | 0,D+DO             | AAL            | . i      |
|              | (2 bytes)                     |      | 4.        | 1   | 1   | 1         | 0     | 0,D+DO+1           | AAH            | 1        |
|              | (5,6 and 7 cycles)            | (1)  | 5.<br>5a  | 1   | 1   | 1         | 0     | DBR AA+1           | Data Low       | 1/0      |
|              |                               | 9    | Ja.       |     | 1   |           | . •   | UBR,AAT1           | Data LOW       | . "      |
| <b>*</b> 19. | Direct Indirect Long [d]      |      | 1.        | 1   | 1   | 1         | 1.    | PBR,PC             | Op Code        | 1        |
|              | STA I DA CMP SBC)             | (2)  | 2.<br>2a  | -   | 1   | 0         | 0     | PBB PC+1           | 10             | i        |
|              | (8 Op Codes)                  | (-)  | 3.        | 1   | 1   | 1         | ŏ     | 0,D+DO             | AAL            | - 1      |
|              | (2 bytes)                     |      | 4.        | 1   | 1   | 1         | 0     | 0,D+DO+1           | AAH            | 1        |
|              | (6,7 and 8 cycles)            |      | 5.        | 1   | -1  | 1         | 0     | 0,D+DO+2           | AAB            | 1        |
|              |                               | (1)  | б.<br>6а  | 1   | 1   | 1         | 0     | AAB,AA<br>AAB AA+1 | Data Low       | 1/0      |
| 20a          | Absolute Indexed Indirect (a) | •    | 1         | · . | ÷.  | ÷ È       | 1     | PBB PC             | On Code        | 1        |
| 200          | (JMP)                         | ~/   | 2.        | 1   | - i | Ó         | 1     | PBR,PC+1           | AAL            | 1        |
|              | (1 Op Code)                   |      | 3.        | 1   | 1   | Ó         | 1     | PBR,PC+2           | AAH            | 1        |
|              | (3 bytes)                     |      | 4.        | 1   | 1   | 0         | 0     | PBR,PC+2           | 10             | 1        |
|              | (6 cycles)                    |      | 5.<br>6   | 1   | 1.  | 0         | : ÷   | PBR AA+X+1         | NEW PCL        |          |
|              |                               |      | 1.        | 1   | i   | 1         | : i   | PBR, NEW PC        | Op Code        | 1        |
| #20b.        | Absolute Indexed Indirect     |      | 1.        | 1   | 1   | 1         | 1     | PBR,PC             | Op Code        | 1        |
|              | (Jump to Subroutine Indexed   |      | 2.        | 1   | 1   | 0         | 1     | PBR,PC+1           | AAL            | 1        |
|              | Indirect) (a,x)               |      | 3.        | 1   | 1   | 1         | 0     | 0,S                | PCH            | 0        |
|              | (JSR)<br>(1 On Code)          |      | 4.<br>5   | 1   | - i | ò         | 1     | PBR.PC+2           | AAH            | 1        |
|              | (3 bytes)                     |      | 6.        | 1   | 1   | ō         | 0     | PBR,PC+2           | 10             | 1        |
|              | (8 cycles)                    |      | 7.        | 1   | 1   | 0         | 1     | PBR,AA+X           | NEW PCL        | 1        |
|              |                               |      | 8.        | 1   | 1   | 0         | 1     | PBR,AA+X+1         | NEW PCH        | 1        |
| 210          | Stack (Hardware               |      | 1.        |     |     | 4         | 1     | PDD DC             | INBAL OF COU   | 1 3      |
| 214.         | Interrupts) &                 | (3)  | 2         | 1   | ÷   | 0         | 0     | PBB.PC             | 10             | - 1      |
|              | (IRQ,NMI,ABORT,RES)           | (7)  | 3.        | 1   | 1   | ĩ         | 0     | 0,S                | PBR            | 0        |
|              | (4 hardware interrupts)       |      | 4.        | 1   | 1   | 1         | 0     | 0,S-1              | PCH            | 0        |
|              | (0 bytes)<br>(7 and 8 cycles) |      | 5.<br>6   | 1   | 1   | 1         | 0     | 0.5-2              | PCL            | 0        |
|              | (7 and 6 cycles)              |      | 7.        | ò   | i   | - i -     | ŏ     | 0.VA               | AAVL           | 1        |
|              |                               |      | 8.        | 0   | 1   | 1         | 0     | 0,VA+1             | AAVH           | 1        |
|              |                               |      | 1.        | 1   | -1  | 1         | 1     | 0,AAV              | Next Op Cod    | e 1      |
| 21b.         | Stack (Software               | 121  | 1.        | 1   | 1   | 1         | 1     | PBR,PC             | Op Code        | 1        |
|              | Interrupts) s                 | (7)  | 2.        | 1   | 1   | 0         | 1     | PBH,PC+1           | Signature      | 1        |
|              | (2 Op Codes)                  | (.,) | 4.        | 1   | i   | 1         | ŏ     | 0.S-1              | PCH            | ŏ        |
|              | (2 bytes)                     |      | 5.        | 1   | 1   | 1         | 0     | 0,S-2              | PCL            | 0        |
|              | (7 and 8 cycles)              |      | 6.        | 1   | 1   | 1         | 0     | 0,S-3 (COP La      | atches) P      | 0        |
|              |                               |      | 7.<br>8   | 0   | 1   | - 1       | 0     | 0,VA<br>0 VA+1     | AAVL           | 1        |
|              |                               |      | 1.        | 1   | 1   | 1         | 1     | 0,AAV              | Next Op Cod    | le 1     |
| 21c.         | Stack (Return from            |      | 1.        | 1   | -1  | 1         | 1     | PBR.PC             | Op Code        | . 1      |
|              | Interrupt) s                  |      | 2.        | 1   | 1   | 0         | 0     | PBR,PC+1           | 10             | 1        |
|              | (RTI)                         | (3)  | 3.        | 1   | 1   | 0         | 0     | PBR,PC+1           | 10             | <u>1</u> |
|              | (1 Op Code)                   |      | 4.        | 1   | 1   | 1         | 0     | 0,5+1              | PCI            | 1        |
|              | (6 and 7 cycles)              |      | 6.        | - i | ÷   | - i       | 0     | 0,S+2              | PCH            | 1        |
|              | (different order from N6502)  | (7)  | 7.        | 1   | 1   | 1         | 0     | 0,S+4              | PBR            | 1        |
|              |                               |      | 1.        | 1   | 1   | 1         | 1     | PBR,PC             | New Op Cod     | le 1     |
| 21d.         | Stack (Return from            |      | 1.        | 1   | !   | 1         | 1     | PBR.PC             | Op Code        | 1        |
|              | Subroutine) 8                 |      | 2.        | 1   | 1   | 0         | 0     | PBR PC+1           |                | 1        |
|              | (1 Op Code)                   |      | 4.        | - 1 | 1   | 1         | ŏ     | 0.S+1              | PCL            | - 1      |
|              | (1 byte)                      |      | 5.        | 1   | 1   | 1         | ō     | 0,S+2              | PCH            | 1        |
|              | (6 cycles)                    |      | 6.        | 1   | 1   | 0         | 0     | 0,S+2              | 10             | 1        |
|              |                               |      | 1.        | 1   | 1   | 1         | . 1   | PBR,PC             | Op Code        | 1        |
| #21e.        | Stack (Return from            |      | 1.        | 1   | 1   | 1         | 1     | PBR,PC             | Op Code        | 1        |
|              | Subroutine Long) s            |      | 2.<br>3   | - ; | 1   | 0         | 0     | PBR PC+1           | 10             | 1        |
|              | (1 Op Code)                   |      | 4.        | - i | 1   | 1         | ŏ     | 0,S+1              | NEW PCL        | · 1      |
|              | (1 byte)                      |      | 5.        | 1   | 1   | 1         | 0     | 0,S+2              | NEW PCH        | -1       |
|              | (6 cycles)                    |      | 6.        | 1   | 1   | 1         | 0     | 0,S+3              | NEW PBR        | 1        |
|              |                               |      | т.        |     | 1   | - 1       | 1     | NEW PDR,PC         | Hexi Op Cot    | 10 1     |

|               | ADDRESS MODE                                      |             | CYCLE         | VP, | ML, | VDA, V | PA  | ADDRESS BUS          | DATA BUS                  | R/Ŵ      |
|---------------|---------------------------------------------------|-------------|---------------|-----|-----|--------|-----|----------------------|---------------------------|----------|
| 211.          | Stack (Push) s                                    |             | 1.            | 1   | i i | 1      | 1   | PBR,PC               | Op Code                   | 1        |
|               | (PHP,PHA,PHY,PHX,                                 | (1)         | 2.            | 1   | 1   | 0      | 0   | PBR,PC+1             | 10<br>Register High       | 1        |
|               | (7 Op Codes)                                      | .0          | 3.            | i   | 1   | - i .  | 0   | 0,S-1                | Register Low              | i        |
|               | (1 byte)                                          |             |               |     |     |        |     |                      |                           |          |
| 210           | Stack (Pull) s                                    |             | 1             | 1   | 1   | 1      | 1   | PBB PC               | On Code                   | i i      |
| 2. g.         | (PLP,PLA,PLY,PLX,PLD,PL                           | .B)         | 2.            | i.  | 1   | Ó      | ò   | PBR,PC+1             | 10                        | 1        |
|               | (Different than N6502)<br>(6 On Codes)            |             | 3.            | 1   | 1   | 0      | 0   | PBR,PC+1<br>0 S+1    | IO<br>Register Low        | 1        |
|               | (1 byte)                                          | (1)         | 4a.           | 1.  | - 1 | i      | ŏ   | 0,S+2                | Register High             | i        |
|               | (4 and 5 cycles)                                  |             |               |     | ۰.  |        |     |                      |                           |          |
| 21n.          | Stack (Push Effective<br>Indirect Address) s      |             | 1.            | 1   | 1   | 0      | 1   | PBR,PC+1             | DO Code                   | 1        |
|               | (PEI)                                             | (2)         | 2a.           | 1   | 1   | 0      | 0   | PBR,PC+1             | 10                        | 1        |
|               | (1 Op Code)<br>(2 bytes)                          |             | 3.<br>4.      | 1   | 1   | 1      | 0   | 0,D+DO<br>0,D+DO+1   | AAL                       | 1        |
|               | (6 and 7 cycles)                                  |             | 5.            | -1  | 1   | 1      | 0   | 0,S                  | AAH                       | 0        |
| +240          | Stack (Bush Effective                             |             | 6.            | 1.  | 1   | ;      | 0   | 0,5-1                | AAL<br>On Code            | 1        |
| ₹211.         | Absolute Address) s                               |             | 2.            | i   | 1   | ò      | i.  | PBR,PC+1             | AAL                       | i.       |
|               | (PEA)                                             |             | 3.            | 1   | 1   | 0      | 1   | PBR,PC+2             | AAH                       | 1        |
|               | (3 bytes)                                         |             | 4.<br>5.      | 1.  | 1   | - 1    | 0   | 0.S-1                | AAL                       | ŏ        |
|               | (5 cycles)                                        |             |               |     |     |        |     |                      |                           |          |
| <b>*</b> 21j  | Stack (Push Effective<br>Program Counter Belative |             | 1.            | 1   | 1   | 1      | 1   | PBR,PC<br>PBR PC+1   | Op Code<br>Offset Low     | 1        |
|               | Address) s                                        |             | 3.            | 1   | i   | ŏ      | i . | PBR,PC+2             | Offset High               | i.       |
|               | (PER)                                             |             | 4.            | 1   | 1   | 0      | 0   | PBR,PC+2             | IO<br>PCH+OEE+            | 1        |
|               | (3 bytes)                                         |             | 5.            |     | •   | · ·    | Č,  | 0,0                  | CARRY                     | v        |
|               | (6 cycles)                                        |             | 6             | 1   | 1   | 1      | 0   | 0,S-1                | PCL+OFFSET                | 0        |
| <b>*</b> 22   | Stack Relative d,s                                |             | 1.            | 1   | 1   | 1      | 1   | PBR.PC               | Op Code                   | 1        |
|               | STALDA, CMP, SDC)                                 |             | 2.            | 1   | 1   | 0      | ò   | PBR.PC+1             | 10                        | 1        |
|               | (8 Op Codes)                                      |             | 4.            | 1   | 1   | 1      | 0   | 0,S+SO               | Data Low                  | 1/0      |
|               | (2 bytes)<br>(4 and 5 cycles)                     | (1)         | 4a.           | 1   | 1   | 1      | 0   | 0,5+50+1             | Data High                 | 1/0      |
| *23.          | Stack Relative Indirect                           |             | 1             | 1   | 1   | 1      | 1   | PBR.PC               | Op Code                   | 1        |
| 201           | Indexed (d,s),y                                   |             | 2.            | i   | i   | ò      | 1   | PBR.PC+1             | so                        | 1        |
|               | (ORA,AND,EOR,ADC,<br>STA L DA CMP SDC)            |             | 3.            | 1   | 1   | 0      | 0   | PBR+PC+1<br>0.S+SO   |                           | 1        |
|               | (8 Op Codes)                                      |             | 5.            | i   | i   | i      | ŏ   | 0.S+SO+1             | AAH                       | 1        |
|               | (2 bytes)<br>(7 and 8 Cycles)                     |             | 6.<br>7       | 1   | 1   | 0      | 0   | 0,S+SO+1<br>DBB 44+Y | IO<br>Data Low            | 1<br>1/0 |
|               | (r and o Oycics)                                  | (1)         | 7a.           | i   | i   | 1      | õ   | DBR,AA+Y+1           | Data High                 | 1/0      |
| 24a.          | Block Move Positive                               |             | [ <u>1</u> .] | 1   | 1   | 1      | 1   | PBR.PC               | Op Code                   | 1        |
|               | (forward) xyc<br>(MVP)                            |             | 3.            | 1   | 1   | 0      | 1.  | PBR.PC+2             | SBA                       | 1        |
|               | (1 Op Code)                                       | N-2         | 4.            | 1   | 1   | 1      | 0   | SBA,X                | Source Data               | 1        |
|               | (3 bytes)<br>(7 cycles)                           | C=2         | 6.            | 1   | 1   | 0      | 0   | DBA,Y<br>DBA,Y       | IO                        | 1        |
|               | x = Source Address                                |             | L7.           | 1   | 1   | 0      | 0   | DBA,Y                | 10                        | 1        |
|               | y = Destination<br>c =Number of Bytes to Mo       | ve -1       | 1.            | 1   | 1   | 1      | 1.  | PBR,PC<br>PBR,PC+1   | Op Code<br>DBA            | 1        |
|               | x,y Decrement                                     |             | 3.            | - į | . † | ō      | 1   | PBR,PC+2             | SBA                       | 1        |
|               | MVP is used when the                              | N-1<br>Byte | 4.            | 1   | 1   | 1      | 0   | SBA,X-1<br>DBA,Y-1   | Source Data<br>Dest. Data | 1        |
|               | is higher (more positive)                         | C=1         | 6.            | 1   | 1   | 0      | ō   | DBA,Y-1              | 10                        | 1        |
|               | than the source start add                         | ress.       | 7.            | 1   | 1   | 0      | 0   | DBA,Y-1              | 10<br>0- 0- de            | 1        |
|               | FFFFFF                                            |             | 2.            | 1   | ÷   | ò      | 1   | PBR.PC+1             | DBA                       | i.       |
|               | Dest. Start                                       | N Byte      | 3.            | 1   | 1   | 0      | 1   | PBR,PC+2             | SBA                       | 1        |
|               | -Source Start                                     | C=0         | 5.            | 1   | 1   | 1      | ő   | DBA,Y-2              | Dest. Data                | ò        |
|               | Dest. End                                         |             | 6.            | 1   | 1   | 0      | 0   | DBA,Y-2              | 10                        | 1        |
|               | 000000                                            |             | Ľí.           | i   | 1   | 1      | 1   | PBR,PC+3             | Next Op Code              | 1        |
|               |                                                   |             |               |     |     |        |     |                      |                           |          |
| <b>*</b> 24b. | Block Move Negative                               |             | [1.           | 1   | 1   | 1      | 1   | PBR,PC               | Op Code                   | 1        |
|               | (Dackward) xyc<br>(MVN)                           | N-2         | 3.            | 1   | 1   | 0      | 1   | PBR,PC+2             | SBA                       | 1        |
|               | (1 Op Code)                                       | Byte        | 4.            | 1   | 1   | 1.1    | 0   | SBA,X                | Source Data               | 1        |
|               | (3 bytes)<br>(7 cycles)                           |             | 6.            | 1   | 1   | ò      | ő   | DBA,Y                | IO                        | 1        |
|               | x = Source Address                                |             | 7.            | 1   | 1   | 0      | 0   | DBA,Y                | ю                         | 1        |
|               | c = Number of Bytes to M                          | ove -1      | [1. 1         | 1   | 1   | 1      | 1   | PBR,PC               | Op Code                   | 1        |
|               | x,y Increment                                     | N-1         | 2.            | 1   | 1   | 0      | 1   | PBR,PC+1             | DBA                       | 1        |
|               | FFFFFF                                            | Byte        | 4.            | 1   | 1   | 1      | ò   | SBA,X+1              | Source Data               | 1        |
|               | Source End                                        | C=1         | 5.            | 1   | -1  | 1      | 0   | DBA,Y+1<br>DBA Y+1   | Dest. Data                | 0        |
|               | Dest.End                                          |             | 7.            | 1   | 1   | õ      | 0   | DBA,Y+1              | 10                        | i        |
|               | Dest. Start                                       |             | Ē.            | - 1 | 1   | 1      | 1   | PBR,PC               | Op Code                   | 1        |
|               | +                                                 |             | 2.            | 1   | 1   | 0      | 1   | PBR,PC+1<br>PBR PC+2 | SBA                       | 1        |
|               | 000000                                            | C=0         | 4.            | í   | 1   | 1      | ò   | SBA,X+2              | Source Data               | i        |
|               | MVN is used when the                              |             | 5.            | 1   | 1   | 1      | 0   | DBA,Y+2<br>DBA Y+2   | Dest. Data                | 0        |
|               | is lower (more negative)                          |             | 7.            | 1   | 1   | ŏ      | ŏ   | DBA,Y+2              | 10                        | 1.       |
|               | than the source start                             |             | D.            | 1   | 1   | 1      | 1   | PBR,PC+3             | Next Op Code              | : 1      |



## TABLE 5. NOTES

Notes: 1. Bit immediate N and V flags not affected. When M = 0, M<sub>15</sub> → N and M<sub>14</sub> →V. 2. Break Bit (B) in Status register indicates hardware or software break.

3. ★ = New 65C816/802 Instructions ● = New 65C02 Instructions Blank = NMOS 6502

+ Add - Subtract ∧ AND

## **TABLE 6. NOTES**

#### Notes

- (1) Add 1 byte (for immediate only) for M=0 or X=0 (i.e. 16 bit data), add 1 cycle for M=0 or X=0 (2) Add 1 cycle for direct register low (DL) not equal 0.
- (3) Special case for aborting instruction. This is the last cycle which may be aborted or the Status, PBR or DBR registers will be updated.
- (4) Add 1 cycle for indexing across page boundaries, or write, or X=0. When X=1 or in the emulation mode, this cycle contains invalid address
- (5) Add 1 cycle if branch is taken.
- (6) Add 1 cycle if branch is taken across page boundaries in 6502 emulation mode (E=1).
- (7) Subtract 1 cycle for 6502 emulation mode (E=1).
- (8) Add 1 cycle for REP,SEP.
- (9) Wait at cycle 2 for 2 cycles after NMI or IRQ active input

Abbreviations

- AAB Absolute Address Bank AAH Absolute Address High AAI Absolute Address Low AAVH Absolute Address Vector High AAVL Absolute Address Vector Low C Accumulator D Direct Register DBA Destination Bank Address DBR Data Bank Register DO Direct Offset IDH Immediate Data High IDL Immediate Data Low IO Internal Operation P Status Register PBR Program Bank Register PC Program Counter R-M-W Read-Modify-Write S Stack Address SBA Source Bank Address SO Stack Offset VA Vector Address x,y Index Registers
- ★ = New 35C816/802 Addressing Modes New 65C02 Addressing Modes Blank = NMOS 6502 Addressing Modes

## RECOMMENDED ASSEMBLER SYNTAX STANDARDS

#### DIRECTIVES

Assembler directives are those parts of the assembly language source program that give directions to the assembler: this includes the definition of data area and constants within a program. This standard excludes any definitions of assembler directives.

### COMMENTS

An assembler should provide a way to use any line of the source program as a comment. The recommended way of doing this is to treat any blank line, or any line that starts with a semi-colon or an asterisk, as a comment. Other special characters may be used as well.

#### THE SOURCE LINE

Any line that causes the generation of a single VL65C816 or VL65C802 machine language instruction should be divided into four fields: a label field, the operation code, the operand, and the comment field.

The Label Field - The label field begins in column one of the line. A label must start with an alphabetic character, and may be followed by zero or more alphanumeric characters. An assembler may define an upper limit on the number of characters that can be in a label, as

long as that upper limit is greater than or equal to six characters. An assembler may limit the alphabetic characters to upper-case characters if desired. If lower-case characters are allowed, they should be treated as identical to their upper-case equivalents. Other characters may be allowed in the label. as long as their use does not conflict with the coding of operand fields.

The Operation Code Field - The operation code consists of a threecharacter sequence (mnemonic) from table 2. It starts no sooner than column two of the line, or one space after the label if a label is coded.

Many of the operation codes in table 2 have duplicate mnemonics; when two or more machine language instructions have the same mnemonic, the assembler resolves the difference based on the operand.

If an assembler allows lower-case letters in labels, it must also allow lower case letters in mnemonics. When lowercase letters are used in the mnemonic. they are treated as equivalent to the upper-case counterpart. Thus, the mnemonics LDA, Ida, and LdA must all be recognized, and are equivalent.

In addition to the mnemonics shown in table 2, an assembler may provide the alternative mnemonics shown in table 7.

SJL should be recognized as equivalent to JSR when it is specified with a long absolute address. JML is equivalent to JMP with long addressing force.

The Operand Field - The operand field may start no sooner than one space after the operation code field. The assembler must be capable of at least 24-bit address calculations. The assembler should be capable of specifying addresses as labels, integer constants, and hexadecimal constants. The assembler must allow addition and subtraction in the operand field. Labels are recognized by the fact that they start with alphabetic characters. Decimal numbers are recognized as containing only the decimal digits 0 through 9. Hexadecimal constants shall be recognized by prefixing the constant with a dollar sign (\$) character, followed by zero or more of either the decimal digits or the hexadecimal digits A through F. If lower case letters are allowed in the label field, then they are also allowed as hexadecimal digits.

All constants, no matter what their format, provide at least enough precision to specify all values that can be represented by a 24-bit signed or unsigned integer represented in two's complement notation.

Table 9 shows the operand formats that are recognized by the assembler. The symbol d is a label or value that the assembler can recognize as being less than #100. The symbol a is a label or value which the assembler can recognize as greater than \$FF but less than \$10000; the symbol al is a label or value that the assembler can recognize as being greater than \$FFFF. The symbol EXT is a label that cannot be located by the assembler at the time the instruction is assembled. Unless instructed otherwise, an assembler assumes that EXT labels are two bytes long. The symbols r and rl are 8- and 16bit signed displacements calculated by the assembler.

Note that the operand does not determine whether or not immediate addressing loads one or two bytes; this is determined by the setting of the status register. This forces the requirement for a directive or directives that tell the assembler to generate one or two bytes of space for immediate loads. The directives provided must allow separate settings for the accumulator and index registers.

The assembler shall use the <, >, and ^

characters after the # character in an immediate address to specify which byte or bytes are to be selected from the value of the operand. Any calculations in the operand must be performed before the byte selection takes place. Table 8 defines the action taken by each operand by showing the effect of the operator on an address. The column that shows a two-byte immediate value shows the bytes in the order in which they appear in memory. The coding of the operand is for an asembler that uses 32 bit address calculations, showing the way that the address should be reduced to a 24 bit value.

In any location in an operand in which an address, or expression resulting in an address, can be coded, the assembler recognizes the prefix characters <. |. and >, which force one-byte (direct page), two-byte (absolute) or three-byte (long absolute) addressing. In cases in which the addressing mode is not forced, the assembler shall assume that the address is two bytes unless the assembler is able to determine the type of addressing required by context, in which case that addressing mode is used. Addresses are truncated without error if an addressing mode is forced that does not require the entire value of the address. For example:

| LDA | \$0203   |
|-----|----------|
| LDA | \$010203 |

are completely equivalent. If the

addressing mode is not forced, and the type of addressing cannot be determined from context, the assembler assumes that a two-byte address is to be used. If an instruction does not have a short addressing mode (as in LDA. which has no direct page indexed by Y) and a short address is used in the operand, the assembler automatically extends the address by padding the most significant bytes with zeroes in order to extend the address to the length needed. As with immediate addressing, any expression evaluation takes place before the address is selected: thus, the address selection character is only used once, before the address of expression.

The exclamation point (!) character should be supported as an alternative to the vertical bar (!).

A long indirect address is indicated in the operand field of an instruction by surrounding the direct page address where the indirect address is found by square brackets; direct page addresses that contains 16-bit addresses are indicated by being surrounded by parentheses.

The operands of a block move instruction are specified as source bank, destination band (the opposite order of the object bytes generated).

Comment Field -The comment field may start no sooner than one space after the operation code field or operand code field or operand field, depending on instruction type.

## TABLE 7. ALTERNATIVE MNEMONICS

| Standard | Alias |
|----------|-------|
| BCC      | BLT   |
| BCS      | BGE   |
| CMP A    | CMA   |
| DEC A    | DEA   |
| INC A    | INA   |
| JSL      | JSR   |
| JML      | JMP   |
| TCD      | TAD   |
| TCS      | TAS   |
| TDC      | TDA   |
| TSC      | TSA   |
| XBA      | SWA   |
|          |       |

## **TABLE 8. BYTE SELECTION OPERATOR**

| Operand      | One Byte Result | Two Byte Resul |    |  |  |  |
|--------------|-----------------|----------------|----|--|--|--|
| #\$01020304  | 04              | 04             | 03 |  |  |  |
| #<\$01020304 | 04              | 04             | 03 |  |  |  |
| #>\$01020304 | 03              | 03             | 02 |  |  |  |
| #^\$01020304 | 02              | 02             | 01 |  |  |  |

## TABLE 9. ADDRESS MODE FORMATS

| Addressing Mode       | Format                                                                             | Addressing Mode       | Format                                       |                           |
|-----------------------|------------------------------------------------------------------------------------|-----------------------|----------------------------------------------|---------------------------|
| Immediate             | #d                                                                                 | Absolute Indexed by Y | !d,y                                         |                           |
|                       | #a                                                                                 |                       | d.v                                          |                           |
|                       | #al                                                                                |                       | a.v                                          |                           |
|                       | #EXT                                                                               |                       | lav                                          |                           |
|                       | # <d< td=""><td></td><td>lalv</td><td></td></d<>                                   |                       | lalv                                         |                           |
|                       | # <a< td=""><td></td><td>IEXT.v</td><td></td></a<>                                 |                       | IEXT.v                                       |                           |
|                       | # <al< td=""><td></td><td>FXTV</td><td></td></al<>                                 |                       | FXTV                                         |                           |
|                       | # <fxt< td=""><td>Absolute Long Indexed</td><td>&gt;d v</td><td></td></fxt<>       | Absolute Long Indexed | >d v                                         |                           |
|                       | #>d                                                                                | by X                  | >a x                                         |                           |
|                       | #>a                                                                                | -,                    | Salx                                         |                           |
|                       | #>al                                                                               |                       | alx                                          |                           |
|                       | #>FXT                                                                              |                       | >FXT x                                       |                           |
|                       | #^d                                                                                | Program Counter       | d                                            | (the assembler calculates |
|                       | #Aa                                                                                | Belative and          | a                                            | r and ri)                 |
|                       | #Aal                                                                               | Program Counter       | al                                           | T und II)                 |
|                       | #AEXT                                                                              | Belative Long         | FXT                                          |                           |
| Absolute              | Id                                                                                 | Absolute Indirect     | (d)                                          |                           |
| , looonato            | la                                                                                 |                       | (ld)                                         |                           |
|                       | a                                                                                  |                       | (a)                                          |                           |
|                       | lal                                                                                |                       | (u)<br>(la)                                  |                           |
|                       | IEXT                                                                               |                       | (lal)                                        |                           |
|                       | FXT                                                                                |                       | (EXT)                                        |                           |
| Absolute Long         |                                                                                    | Direct Indirect       | (d)                                          |                           |
| Absolute Long         | >0<br>>a                                                                           | Bireet indirect       | (G)<br>(≤a)                                  |                           |
|                       | ~α<br>∖al                                                                          |                       | ( <a)<br>(<a)< td=""><td></td></a)<></a)<br> |                           |
|                       | ∕αi<br>al                                                                          |                       |                                              |                           |
|                       |                                                                                    | Direct Indirect Long  |                                              |                           |
| Direct Page           | d LAT                                                                              | Direct maneet Long    | [U]<br>[ <a]< td=""><td></td></a]<>          |                           |
| Direct rage           | d<br>Cd                                                                            |                       | [ <a]< td=""><td></td></a]<>                 |                           |
|                       |                                                                                    |                       |                                              |                           |
|                       | <u<br><al< td=""><td>Absolute Indexed</td><td>(dx)</td><td></td></al<></u<br>      | Absolute Indexed      | (dx)                                         |                           |
|                       | < FXT                                                                              |                       | $(\mathbf{d},\mathbf{x})$                    |                           |
| Accumulator           | A                                                                                  |                       | (a.x)                                        |                           |
| Implied Addressing    | (no operand)                                                                       |                       | (la.x)                                       |                           |
| Direct Indirect       | (d).v                                                                              |                       | (!al.x)                                      |                           |
| Indexed               | ( <d).y< td=""><td></td><td>(EXT,x)</td><td></td></d).y<>                          |                       | (EXT,x)                                      |                           |
|                       | ( <a),y< td=""><td></td><td>(!EXT,x)</td><td></td></a),y<>                         |                       | (!EXT,x)                                     |                           |
|                       | ( <al),y< td=""><td>Stack Addressing</td><td>(no operand)</td><td></td></al),y<>   | Stack Addressing      | (no operand)                                 |                           |
|                       | ( <ext),y< td=""><td>Stack Relative</td><td>(d,s),y</td><td></td></ext),y<>        | Stack Relative        | (d,s),y                                      |                           |
| Direct Indirect       | [d],y                                                                              | Indirect Indexed      | ( <d,s),y< td=""><td></td></d,s),y<>         |                           |
| Indexed Long          | [ <d],y< td=""><td></td><td>(<a,s),y< td=""><td></td></a,s),y<></td></d],y<>       |                       | ( <a,s),y< td=""><td></td></a,s),y<>         |                           |
| -                     | [ <a],y< td=""><td></td><td>(&lt; al, s), y</td><td></td></a],y<>                  |                       | (< al, s), y                                 |                           |
|                       | [ <al],y< td=""><td></td><td>(<ext,s),y< td=""><td></td></ext,s),y<></td></al],y<> |                       | ( <ext,s),y< td=""><td></td></ext,s),y<>     |                           |
|                       | [ <ext],y< td=""><td>Block Move</td><td>d,d</td><td></td></ext],y<>                | Block Move            | d,d                                          |                           |
| Direct Indexed        | (d,x)                                                                              |                       | d,a                                          |                           |
| Indirect              | ( <d,x)< td=""><td></td><td>d,al</td><td></td></d,x)<>                             |                       | d,al                                         |                           |
|                       | ( <a,x)< td=""><td></td><td>d,EXT</td><td></td></a,x)<>                            |                       | d,EXT                                        |                           |
|                       | ( <al,x)< td=""><td></td><td>a,d</td><td></td></al,x)<>                            |                       | a,d                                          |                           |
|                       | ( <ext,x)< td=""><td></td><td>a,a</td><td></td></ext,x)<>                          |                       | a,a                                          |                           |
| Direct Indexed by X   | d,x                                                                                |                       | a,al                                         |                           |
|                       | <d,x< td=""><td></td><td>a,EXT</td><td></td></d,x<>                                |                       | a,EXT                                        |                           |
|                       | <a,x< td=""><td></td><td>al,d</td><td></td></a,x<>                                 |                       | al,d                                         |                           |
|                       | <al,x< td=""><td></td><td>al,a</td><td></td></al,x<>                               |                       | al,a                                         |                           |
|                       | <ext,x< td=""><td></td><td>al,al</td><td></td></ext,x<>                            |                       | al,al                                        |                           |
| Direct Indexed by Y   | d,y                                                                                |                       | al,EXT                                       |                           |
|                       | <d,y< td=""><td></td><td>EXT,d</td><td></td></d,y<>                                |                       | EXT,d                                        |                           |
|                       | <a,y< td=""><td></td><td>EXT,a</td><td></td></a,y<>                                |                       | EXT,a                                        |                           |
|                       | <ai,y< td=""><td></td><td>EXT,al</td><td></td></ai,y<>                             |                       | EXT,al                                       |                           |
|                       | <ext,y< td=""><td></td><td>EXT,EXT</td><td></td></ext,y<>                          |                       | EXT,EXT                                      |                           |
| Absolute Indexed by X | d,x                                                                                |                       |                                              |                           |
|                       | !d,x                                                                               |                       |                                              |                           |
|                       | a,x                                                                                |                       |                                              |                           |
|                       | la,x                                                                               |                       |                                              |                           |
|                       |                                                                                    |                       |                                              |                           |
|                       |                                                                                    |                       |                                              |                           |
|                       | EAT,X                                                                              |                       |                                              |                           |

Note: The alternate ! (exclamation point) is used in place of the | (vertical bar).

## TABLE 10. ADDRESSING MODE SUMMARY

|                                                            | instructi<br>In Memo           | on Times<br>ry Cycles | Memory Utilization<br>In Number of Program<br>Sequence Bytes |               |  |
|------------------------------------------------------------|--------------------------------|-----------------------|--------------------------------------------------------------|---------------|--|
| Address Mode                                               | Original<br>8 Bit NMOS<br>6502 | New<br>65C816         | Original<br>8 Bit NMOS<br>6502                               | New<br>65C816 |  |
| 1. Immediate                                               | 2                              | 2(3)                  | 2                                                            | 2(3)          |  |
| 2. Absolute                                                | 4(5)                           | 4(3,5)                | 3                                                            | 3             |  |
| 3. Absolute Long                                           | · · · · ·                      | 5(3)                  | -                                                            | 4             |  |
| 4. Direct                                                  | 3(5)                           | 3(3,4,5)              | 2                                                            | 2             |  |
| 5. Accumulator                                             | 2                              | 2                     | 1                                                            | 1             |  |
| 6. Implied                                                 | 2                              | 2                     | 1                                                            | 1             |  |
| 7. Direct Indirect Indexed (d),y                           | 5(1)                           | 5(1,3,4)              | 2                                                            | 2             |  |
| <ol><li>Direct Indirect Indexed Long [d], y</li></ol>      |                                | 6(3,4)                | -                                                            | 2             |  |
| 9. Direct Indexed Indirect (d,x)                           | 6                              | 6(3.4)                | 2                                                            | 2             |  |
| 10. Direct, X                                              | 4(5)                           | 4(3,4,5)              | 2                                                            | 2             |  |
| 11. Direct, Y                                              | 4                              | 4(3,4)                | 2                                                            | 2             |  |
| 12. Absolute, X                                            | 4(1,5)                         | 4(1,3,5)              | 3                                                            | 3             |  |
| 13. Absolute Long, X                                       |                                | 5(3)                  | _                                                            | 4             |  |
| 14. Absolute, Y                                            | 4(1)                           | 4(1,3)                | 3                                                            | 3             |  |
| 15. Relative                                               | 2(1,2)                         | 2(2)                  | 2                                                            | 2             |  |
| 16. Relative Long                                          |                                | 3(2)                  | · · · ·                                                      | 3             |  |
| 17. Absolute Indirect (Jump)                               | 5                              | 5                     | 3                                                            | 3             |  |
| 18. Direct Indirect                                        | _                              | 5(3,4)                | ·                                                            | 2             |  |
| 19. Direct Indirect Long                                   |                                | 6(3,4)                | -                                                            | 2             |  |
| 20. Absolute Indexed Indirect (Jump)                       |                                | 6                     |                                                              | 3             |  |
| 21. Stack                                                  | 3-7                            | 3-8                   | 1-3                                                          | 1-4           |  |
| 22. Stack Relative                                         | _                              | 4(3)                  | _                                                            | 2             |  |
| 23. Stack Relative Indirect Indexed                        |                                | 7(3)                  | _ · · _ · ·                                                  | 2             |  |
| 24. Block Move X, Y, C (Source, Destination, Block Length) |                                | 7                     |                                                              | 3             |  |

NOTES:

Page boundary, add 1 cycle if page boundary is crossed when forming address.
 Branch taken, add 1 cycle if branch is taken.
 M = 0 or X = 0, 16 bit operation, add 1 cycle, add 1 byte for immediate.

5. Min = 0 f X = 0, for the periation, and a register i on infinedation.
6. Direct register low (DL) not equal zero, add 1 cycle.
6. Read-Modify-Write, add 2 cycles for M = 1, add 3 cycles for M = 0.

## ADDRESSING PREFACE

The VL65C816 is capable of directly addressing 16M Bytes of memory. This address space has special significance within certain addressing modes.

#### RESET AND INTERRUPT VECTORS

The Reset and Interrupt vectors use the majority of the fixed addresses between 00FFE0 and 00FFFF.

#### STACK

The stack may use memory from 000000 to 00FFFF. The effective address of Stack and Stack Relative addressing modes is always within this range.

#### DIRECT

The Direct addressing modes are usually used to store memory registers and pointers. The effective address generated by Direct, Direct,X and Direct, Y addressing modes is always in Bank 0 (000000-00FFFF).

#### PROGRAM ADDRESS SPACE

The Program Bank Register is not affected by the Relative, Relative Long, Absolute, Absolute Indirect, and Absolute Indexed Indirect addressing modes or by incrementing the Program Counter from FFFF. The only instructions that affect the Program Bank Register are: RTI, RTL, JML, JSL, and JMP Absolute Long. Program code may exceed 64K bytes, although code segments may not span bank boundaries.

### DATA ADDRESS SPACE

The data address space is contiguous throughout the 16M Byte address space. Words, arrays, records, or any data structures may span 64K Byte bank boundaries with no compromise in code efficiency. The following addressing modes generate 24-bit effective addresses:

- Direct Indexed Indirect (d,x)
- Direct Indirect Indexed (d), y
- · Direct Indirect (d)
- Direct Indirect Long [d]
- · Direct Indirect Long Indexed [d], y
- Absolute a
- Absolute a, x
- Absolute a, y
- Absolute Long al
- Absolute Long Indexed al, x
- · Stack Relative Indirect Indexed (d), y

The following addressing modes are available for use in the VL65C802 and VL65C816 microprocessors. The "long" addressing modes may be used with the VL65C802; however, the high byte of the address is not available to the hardware. Detailed descriptions of the 24 addressing modes are given in the following section.

## ADDRESSING MODES

#### 1. Immediate Addressing-#

The operand is the second byte (second and third bytes when in the 16-bit mode) of the instruction.

#### 2. Absolute-a

With Absolute addressing the second and third bytes of the instruction form the low-order 16 bits of the effective address. The Data Bank Register contains the high-order 8 bits of the operand address.

| Instruction:        | opcode | addrl | addrh |
|---------------------|--------|-------|-------|
| Operand<br>Address: | DBR    | addrh | addrl |

#### 3. Absolute Long-al

The second, third, and fourth byte of the instruction form the 24-bit effective address.

| Instruction:        | opcode | addrl | addrh | baddr |
|---------------------|--------|-------|-------|-------|
| Operand<br>Address: | baddr  | addrh | addri |       |

#### 4. Direct-d

The second byte of the instruction is added to the Direct Register (D) to form the effective address. An additional cycle is required when the Direct Register is not page aligned (DL not equal 0). The Bank register is always 0.



#### 5. Accumulator-A

This form of addressing always uses a single byte instruction. The operand is the Accumulator.

## 6. Implied—i

Implied addressing uses a single byte instruction. The operand is implicitly defined by the instruction.

### 7. Direct Indirect Indexed—(d),y

This address mode is often referred to as Indirect,Y. The second byte of the instruction is added to the Direct Register (D). The 16-bit contents of this memory location is then combined with the Data Bank register to form a 24-bit base address. The Y Index Register is added to the base address to form the effective address.



### 8. Direct Indirect Long Indexed-[d],y

With this addressing mode, the 24-bit base address is pointed to by the sum of the second byte of the instruction and the Direct Register. The effective address is this 24-bit base address plus the Y Index Register.



## ADDRESSING MODES (Cont.)



#### 9. Direct Indexed Indirect-(d,x)

This address mode is often referred to as Indirect,X. The second byte of the instruction is added to the sum of the Direct Register and the X Index Register. The result points to the low-order 16 bits of the effective address. The Data Bank Register contains the high-order 8 bits of the effective address.



#### 10. Direct Indexed With X-d,x

The second byte of the instruction is added to the sum of the Direct Register and the X Index Register to form the 16-bit effective address. The operand is always in Bank 0.



#### 11. Direct Indexed With Y-d,y

The second byte of the instruction is added to the sum of the Direct Register and the Y Index Register to form the 16-bit effective address. The operand is always in Bank 0.



#### 12. Absolute Indexed With X-a,x

The second and third bytes of the instruction are added to the X Index Register to form the low-order 16 bits of the effective address. The Data Bank Register contains the high-order 8 bits of the effective address.

| Operand<br>Address: | effective address |       |       |  |  |  |  |  |
|---------------------|-------------------|-------|-------|--|--|--|--|--|
|                     | +                 |       | X Reg |  |  |  |  |  |
|                     | DBR               | addrh | addrl |  |  |  |  |  |
| Instruction:        | opcode            | addrl | addrh |  |  |  |  |  |

#### 13. Absolute Long Indexed With X-al,x

The second, third and fourth bytes of the instruction form a 24-bit base address. The effective address is the sum of this 24-bit address and the X Index Register.

| Instruction:        | opcode | addrl | addrh | baddr                     |
|---------------------|--------|-------|-------|---------------------------|
|                     | baddr  | addrh | addrl |                           |
|                     | +      |       | X Reg | l a station de la company |
| Operand<br>Address: | ef     | Ī     |       |                           |

#### 14. Absolute Indexed With Y-a,y

The second and third bytes of the instruction are added to the Y Index Register to form the low-order 16 bits of the effective address. The Data Bank Register contains the high-order 8 bits of the effective address.

| Instruction:        | opcode | addrl             | addrh |  |  |  |  |
|---------------------|--------|-------------------|-------|--|--|--|--|
|                     | DBR    | addrh             | addrl |  |  |  |  |
|                     | +      |                   | Y Reg |  |  |  |  |
| Operand<br>Address: | ef     | effective address |       |  |  |  |  |

### 15. Program Counter Relative-r

This address mode, referred to as Relative Addressing, is used only with the Branch instructions. If the condition being tested is met, the second byte of the instruction is added to the Program Counter, which has been updated to point to the opcode of the next instruction. The offset is a signed 8-bit quantity in the range from -128 to 127. The Program Bank Register is not affected.

#### 16. Program Counter Relative Long-rl

This address mode, referred to as Relative Long Addressing, is used only with the Unconditional Branch Long instruction (BRL) and the Push Effective Relative instruction (PER). The second and third bytes of the instruction are added to the Program Counter, which has been updated to point to the opcode of the next instruction. With the branch instruction, the Program Counter is loaded with the result. With the Push Effective Relative instruction, the result is stored on the stack. The offset is a signed 16-bit quantity in the range from -32768 to 32767. The Program Bank Register is not affected.



## ADDRESSING MODES (Cont.)

### 17. Absolute Indirect—(a)

The second and third bytes of the instruction form an address to a pointer in Bank 0. The Program Counter is loaded with the first and second bytes at this pointer. With the Jump Long (JML) instruction, the Program Bank Register is loaded with the third byte of the pointer.

| Instruction:       | opcode         | addrl | addrh | ]     |
|--------------------|----------------|-------|-------|-------|
| Indirect Address = |                | 00    | addrh | addrl |
| New PC = (         | (indirect addr | ess)  |       |       |
| with JML:          |                |       |       |       |
| New PC = (         | indirect addr  | ess)  |       |       |

New PBR = (indirect address +2)

#### 18. Direct Indirect-(d)

The second byte of the instruction is added to the Direct Register to form a pointer to the low-order 16 bits of the effective address. The Data Bank Register contains the high-order 8 bits of the effective address.



#### 19. Direct Indirect Long-[d]

The second byte of the instruction is added to the Direct Register to form a pointer to the 24-bit effective address.



### 20. Absolute Indexed Indirect-(a,x)

The second and third bytes of the instruction are added to the X Index Register to form a 16-bit pointer in Bank 0. The contents of this pointer are loaded in the Program Counter. The Program Bank Register is not changed.



PC = (address)

#### 21. Stack-s

Stack addressing refers to all instructions that push or pull data from the stack, such as Push, Pull, Jump to Subroutine, Return from Subroutine, Interrupts, and Return from Interrupt. The bank address is always 0. Interrupt Vectors are always fetched from Bank 0.

#### 22. Stack Relative-d,s

The low-order 16 bits of the effective address is formed from the sum of the second byte of the instruction and the Stack Pointer. The high-order 8 bits of the effective address is always zero. The relative offset is an unsigned 8-bit quantity in the range of 0 to 255.



#### 23. Stack Relative Indirect Indexed—(d,s),y

The second byte of the instruction is added to the Stack Pointer to form a pointer to the low-order 16-bit base address in Bank 0. The Data Bank Register contains the high-order 8 bits of the base address. The effective address is the sum of the 24-bit base address and the Y Index Register.



#### 24. Block Source Bank, Destination Bank—xyc

This addressing mode is used by the Block Move instructions. The second byte of the instruction contains the high-order 8 bits of the destination address. The Y index Register contains the low-order 16 bits of the destination address. The third byte of the instruction contains the high-order 8 bits of the source address. The X Index Register contains the low-order 16 bits of the source address. The C Accumulator contains one less than the number of bytes to move. The second byte of the block move instructions is also loaded into the Data Bank Register.

| Instruction:            | opcode | dstbnk | srcbnk |  |
|-------------------------|--------|--------|--------|--|
| •                       |        | dstbnk | → DBR  |  |
| Source<br>Address:      |        | scrbnk | X Reg  |  |
| Destination<br>Address: |        | DBR    | Y Reg  |  |

Increment (MVN) or decrement (MVP) X and Y. Decrement C (if greater than zero), then  $PC+3 \rightarrow PC$ .

## TABLE 11. VL65C802 TIMING CHARACTERISTICS TA = 0°C to 70°C, VDD = 5.0 V ± 5%

|                                             |               | 2 MHz |     | 4 MHz                |     | 6 MHz |     | 8 MHz |       | <u> </u> |
|---------------------------------------------|---------------|-------|-----|----------------------|-----|-------|-----|-------|-------|----------|
| Parameter                                   | Symbol        | Min   | Max | Min                  | Max | Min   | Max | Min   | Max   | Unit     |
| Cycle Time                                  | tcyc          | 500   | DC  | 250                  | DC  | 167   | DC  | 125   | DC    | nS       |
| Clock Pulse Width Low                       | tPWL          | 0.240 | 10  | 0.120                | 10  | 0.080 | 10  | 0.060 | 10    | μS       |
| Clock Pulse Width High                      | tpwH          | 240   | œ   | 120                  | ×   | 80    | ∞   | 60    | ~     | nS       |
| Fall Time, Rise Time                        | tF, tR        | ·     | 10  |                      | 10  | -     | 5   | · _ · | 5     | nS       |
| Delay Time, $\phi$ 2 (IN) to $\phi$ 1 (OUT) | tD¢1          |       | 20  | in <del>Co</del> sci | 20  |       | 20  |       | 20    | nS       |
| Delay Time, $\phi^2$ (IN) to $\phi^2$ (OUT) | tD <b>¢</b> 2 | -     | 40  | -                    | 40  |       | 40  |       | 40    | nS       |
| Address Hold Time                           | tан           | 10    | -   | 10                   | -   | 10    | -   | 10    |       | nS       |
| Address Setup Time                          | tads          | -     | 100 | -                    | 75  | _     | 60  |       | 40    | nS       |
| Access Time                                 | tACC          | 365   | —   | 130                  |     | 87    |     | 70    |       | nS       |
| Read Data Hold Time                         | <b>t</b> DHR  | 10    | -   | 10                   | -   | 10    | -   | 10    | · · · | nS       |
| Read Data Setup Time                        | tDSR          | 40    |     | 30                   |     | 20    | -   | 15    | -     | nS       |
| Write Data Delay Time                       | tMDS          |       | 100 | n <u>- 1</u> 000     | 70  | -     | 60  |       | 40    | nS       |
| Write Data Hold Time                        | tohw          | 10    | ·   | 10                   |     | 10    |     | 10    |       | nS       |
| Processor Control Setup Time                | tPCS          | 40    | -   | 30                   | -   | 20    |     | 15    |       | nS       |
| Processor Control Hold Time                 | tрсн          | 10    | _   | 10                   |     | 10    | -   | 10    | _     | nS       |
| Capacitive Load (Address, Data, and R/W)    | Cext          |       | 100 | <u> </u>             | 100 |       | 35  | -     | 35    | pF       |

## FIGURE 3. VL65C802 TIMING DIAGRAM





## TABLE 12. VL65C816 TIMING CHARACTERISTICS TA = 0°C to 70°C, VDD = 5.0 V ± 5%

|                                          |              | 2 MHz |     | 4 MHz |     | z 6 MHz |     | 8 MHz |             |      |
|------------------------------------------|--------------|-------|-----|-------|-----|---------|-----|-------|-------------|------|
| Parameter                                | Symbol       | Min   | Max | Min   | Max | Min     | Max | Min   | Max         | Unit |
| Cycle Time                               | tcyc         | 500   | DC  | 250   | DC  | 167     | DC  | 125   | DC          | nS   |
| Clock Pulse Width Low                    | tPWL         | 0.240 | 10  | 0.120 | 10  | 0.080   | 10  | 0.060 | 10          | μS   |
| Clock Pulse Width High                   | tрwн         | 240   | ~   | 120   | ~   | 80      | ×   | 60    | ~           | nS   |
| Fall Time, Rise Time                     | tr, tr       | -     | 10  |       | 10  |         | 5   | -     | 5           | nS   |
| A0 A15 Hold Time                         | tAH          | 10    | -   | 10    | —   | 10      | -   | 10    | <del></del> | nS   |
| A0-A15 Setup Time                        | tads         | -     | 100 | -     | 75  | _       | 60  | —     | 40          | nS   |
| BA0-BA7 Hold Time                        | tвн          | 10    | _   | 10    | _   | 10      | -   | 10    | _           | nS   |
| BA0-BA7 Setup Time                       | tBAS         | -     | 100 | -     | 90  |         | 65  | -     | 45          | nS   |
| Access Time                              | tacc         | 365   | -   | 130   | -   | 87      | -   | 70    | -           | nS   |
| Read Data Hold Time                      | <b>t</b> DHR | 10    | -   | 10    | -   | 10      | -   | 10    | -           | nS   |
| Read Data Setup Time                     | tdsr         | 40    | -   | 30    | _   | 20      | -   | 15    |             | nS   |
| Write Data Delay Time                    | tMDS         |       | 100 | -     | 70  | -       | 60  |       | 40          | nS   |
| Write Data Hold Time                     | tDHW         | 10    | -   | 10    |     | 10      | -   | 10    | -           | nS   |
| Processor Control Setup Time             | tPCS         | 40    | _   | 30    | -   | 20      | -   | 15    | -           | nS   |
| Processor Control Hold Time              | tPCH         | 10    |     | 10    |     | 10      | -   | 10    |             | nS   |
| E,MX Output Hold Time                    | tен          | 10    | -   | 10    | —   | 5       | _   | 5     | _           | nS   |
| E,MX Output Setup Time                   | tES          | 50    | _   | 50    |     | 25      | —   | 15    | —           | nS   |
| Capacitive Load (Address, Data, and R/W) | Cext         | -     | 100 | -     | 100 | -       | 35  | _     | 35          | pF   |
| BE to High Impedance State               | tвнz         | -     | 30  | -     | 30  | -       | 30  | _     | 30          | nS   |
| BE to Valid Data                         | tevd         | - 1   | 30  | -     | 30  | -       | 30  | -     | 30          | nS   |

## FIGURE 4. VL65C816 TIMING DIAGRAM



## USER INFORMATION STACK ADDRESSING

When in the Native mode, the Stack Register may use memory locations 000000 to 00FFFF. The effective address of Stack, Stack Relative and Stack Relative Indirect Indexed addressing modes is always within this range. In the Emulation mode, the Stack address range is 000100 to 0001FF. The following opcodes and addressing modes increment or

decrement beyond this range when

accessing two or three bytes:

JSL; JSR(a,x); PEA; PEI; PER; PHD; PLD; RTL; d,s; (d,s),y

### DIRECT ADDRESSING

The Direct Addressing modes are often used to access memory registers and pointers. The effective address generated by Direct; Direct, X and Direct, Y addressing modes are always in the Native mode range 000000 to 00FFFF. When in the Emulation mode, the Direct addressing range is 000000 to 0000FF, except for [Direct] and [Direct],Y addressing modes and the PEI instruction, which increment from 0000FE or 0000FF into Stack area.

When in the Emulation mode and DH is not equal to zero, the Direct addressing range is 00DH00 to 00DHFF, except for [Direct] and [Direct],Y addressing modes and the PEI instruction which increment from 00DHFE or 00DHFF into the next higher page.

When in the Emulation mode and DL is not equal to zero, the direct addressing range is 000000 to 00FFFF.

#### ABSOLUTE INDEXED ADDRESSING (VL65C816 ONLY)

The Absolute Indexed addressing modes are used to address data outside the Direct addressing range. The VL65C02 and VL65C802 addressing range is 0000 to FFFF. Indexing from page FFXX may result in a 00YY data fetch when using the VL65C02 or VL65C802. In contrast, indexing from page ZZFFXX may result in ZZ+1,00YY when using the VL65C816.

## ABORT INPUT (VL65C816 ONLY)

ABORT should be held low for a period not to exceed one cycle. Also, if ABORT is held low during the Abort Interrupt sequence, the Abort Interrupt will be aborted. It is not recommended to abort the Abort Interrupt. The ABORT internal latch is cleared during the second cycle of the Abort Interrupt. Asserting the ABORT input after the following instruction cycles causes registers to be modified:

• Read-Modify-Write: Processor Status Register modified if ABORT is asserted after a modify cycle.

• RTI: Processor Status Register modified if ABORT is asserted after cycle 3.

• IRQ, NMI, ABORT BRK, COP: When ABORT is asserted after cycle 2, PBR and DBR become 00 (Emulation mode) or PBRbecomes 00 (Native mode).

The Abort Interrupt has been designed for virtual memory systems. For this reason, asynchronous ABORTs may cause undesirable results due to the above conditions.

### VDA AND VPA (VL65C816 ONLY)

When VDA or VPA are high and during all write cycles, the Address Bus is always valid. VDA and VPA should be used to qualify all memory cycles. Note that when VDA and VPA are both low, invalid addresses may be generated. The Page and Bank addresses could also be invalid. This will be due to low-byte addition only. The cycle when only lowbyte addition occurs is an optional cycle for instructions that read memory when the Index Register consists of eight bits. This optional cycle becomes a standard cycle for the Store instruction, all instructions using the 16-bit Index Register mode, and the Read-Modify-Write instruction when using 8- or 16-bit Index Register modes.

APPLE II, IIe, IIc, AND II+ DISK SYSTEMS (VL65C816 ONLY) VDA and VPA should not be used to qualify addresses during disk operation on Apple systems. Consult your Apple representative for hardware/software configurations.

#### DB/BA OPERATION (WHEN RDY IS PULLED LOW -VL65C816 ONLY)

When RDY is low, the Data Bus is held in the data transfer state (i.e., ø2 high). The Bank address external transparent latch should be latched when the ø2clock or RDY is low.

M/X OUTPUT (VL65C816 ONLY) The M/X output reflects the value of the M and X bits of the processor Status Register. The REP, SEP, and PLP instructions may change the state of the M and X bits. Note that the M/X output is invalid during the instruction cycle following REP, SEP, and PLP instruction execution. This cycle is used as the opcode fetch cycle of the next instruction.

### INSTRUCTIONS

Opcodes - It should be noted that all opcodes function in all modes of operation. However, some instructions and addressing modes are intended for VL65C816 24-bit addressing and are therefore less useful for the VL65C802. The following instructions and addressing modes are primarily intended for VL65C816 use:

> JSL; RTL; [d]; [d],y; JMP al; JML; al; al,x

The following instructions may be used with VL65C802 even though a Bank Address is not multiplexed on the Data Bus:

## PHK; PHB; PLB

The following instructions have limited use in the Emulation mode:

• The REP and SEP instructions cannot modify the M and X bits when in the Emulation mode. In this mode the M and X bits are always high (logic 1).

• When in the Émulation mode, the MVP and MVN instructions use the X and Y Index Registers for the memory address. Also, the MVP and MVN instructions can only move data within the memory range 0000 (Source Bank) to 00FF (Destination Bank) for the VL65C816, and 0000 to 00FF for the VL65C802.

VL65C816•VL65C802 V

## **USER INFORMATION (CONT.)**

Indirect Jumps-The JMP (a) and JML (a) instructions use the direct Bank for indirect addressing, while JMP (a,x) and JSR (a,x) use the Program Bank for indirect address tables.

Switching Modes-When switching from the Native mode to the Emulation mode, the X and M bits of the Status Register are set high (logic 1), the high byte of the Stack is set to 01, and the high bytes of the X and Y Index Registers are set to 00. To save previous values, these bytes must always be stored before changing modes. Note that the low byte of the S, X, and Y Registers and the low and high bytes of the Accumulator (A and B) are not affected by a mode change.

How hardware interrupts, BRK, and COP instructions affect the Program Bank and the Data Bank Registerswhen in the Native mode, the Program Bank register (PBR) is cleared to 00 when a hardware interrupt, BRK or COP is executed. In the Native mode, the previous PBR contents are automatically saved.

Note that a Return from Interrupt (RTI) should always be executed from the same mode that originally generated the interrupt.

Binary Mode-The Binary mode is set whenever a hardware or software interrupt is executed. The D flag within the Status Register is cleared to zero.

WAI Instruction-The WAI instruction pulls RDY low and places the processor in the WAI low-power mode. NMI, IRQ, or RESET terminate the WAI condition and transfer control to the interrupt handler routine. Note that an ABORT input aborts the WAI instruction, but does not restart the processor. When the Status Register 1 flag is set (IRQ disabled), the IRQ interrupt causes the next instruction (following the WAI instruction) to be executed without going to the IRQ interrupt handler. This method results in the highest speed response to an IRQ input. When an interrupt is received after an ABORT that occurs during the WAI instruction, the processor return to the WAI instruction. Other than RES (highest priority), ABORT is the nexthighest priority, followed by NMI or IRQ interrupts.

STP Instruction-The STP instruction disables the  $\sigma$ 2 clock to all circuitry. When disabled, the  $\sigma$ 2 clock is held in the high state. In this case, the Data Bus remains in the data transfer state and the Bank address is not multiplexed onto the Data Bus. Upon executing the STP instruction, the RES signal is the only input that can restart the processor. The processor is restarted by enabling the  $\sigma$ 2 clock, which occurs on the falling edge of the RES input. Note that the external oscillator must be stable and operating properly before RES goes high.

COP Signatures-Signatures 00-7F may be user defined, while signatures 80-FF are reserved.

RDY Pulled During Write-The NMOS 6502 does not stop during a write operation. In contrast, both the VL65C02 and the VL65C816 do stop during write operations. The VL65C802 stops during a write when in the Native mode, but does not stop when in the Emulation mode. MVN and MVP Affects on the Data Bank Register -The MVN and MVP instructions change the Data Bank Register to the value of the second byte of the instruction (destination bank address).

### INTERRUPTS

Interrupt Priorities-The following interrupt priorities are in effect should more than one interrupt occur at the same time:

| RES   | Highest |
|-------|---------|
| ABORT |         |
| NMI   |         |
| IRQ   | Lowest  |

#### TRANSFERS

Transfers from 8-Bit to 16-Bit, or 16-Bit to 8-Bit, Registers - All transfers from one register to another result in a full 16bit output from the source register. The Destination Register size determines the number of bits actually stored in the destination register and the values stored in the processor Status Register. The following are always 16-bit transfers, regardless of the accumulator size:

TCS; TSC; TCD; TDC

Stack Transfers-When in the Emulation mode, a 01 is forced into SH. In this case, the B Accumulator is not loaded into SH during a TCS instruction. When in the Native mode, the B Accumulator is transfered to SH. Note that in both the Emulation and Native modes, the full 16 bits of the Stack Register are transferred to the A, B, and C Accumulators, regardless of the state of the M bit in the Status Register.
# VL65C816•VL65C802

## **ABSOLUTE MAXIMUM RATINGS**

| Ambient Operating                     |                       |
|---------------------------------------|-----------------------|
| Temperature                           | 0°C to +70°C          |
| Storage Temperatu                     | re -55°C to +150°C    |
| Supply Voltage to<br>Ground Potential | -0.3 V to +7.0 V      |
| Applied Input                         |                       |
| Voltage                               | -0.3 V to VDD + 0.3 V |

Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only. Functional operation of this device under these or any conditions other than those indicated in this data sheet is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. This device contains input protection against damage due to high static voltages or electric fields. However, precautions should be taken to avoid application of voltages higher than the maximum rating.

# DC CHARACTERISTICS: TA = 0°C to +70°C, VDD = 5 V $\pm$ 5%

| Parameter                                                                                                                                                          | Symbol     | Min               | Max                    | Unit           |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-------------------|------------------------|----------------|
| In <u>put</u> High Vo <u>ltag</u> e<br>RES, RDY, IRQ, Data, SO, BE,<br>φ2 (IN), NMI, ABORT                                                                         | ViH        | 2.0<br>0.7 Vdd    | VDD + 0.3<br>VDD + 0.3 | v<br>v         |
| In <u>put L</u> ow Voltage<br>RES, RDY, IRQ, Data, SO, BE,<br>¢2 (IN), NMI, ABORT                                                                                  | VIL        | -0.3<br>-0.3      | 0.8<br>0.2             | V<br>V         |
| Input Leakage Current ( <u>VIN</u> = 0 to <u>VDD</u> )<br>RES, NMI, RDV, IRQ, SO, BE, ABORT (Internal Pullup)<br>φ2 (IN)<br>Address, Data, R/W (Off State, BE = 0) | lin        | -100<br>-1<br>-10 | 1<br>1<br>10           | μΑ<br>μΑ<br>μΑ |
| Output High Voltage (IoH = $-100\mu$ A)<br>SYNC, Data, Address, R/W, ML, VP, M/X, E, VDA, VPA,<br>$\phi$ 1 (OUT), $\phi$ 2 (OUT)                                   | Vон        | 0.7 Vdd           |                        | v              |
| Output Low Voltage (IoL = <u>1.6mA</u> )<br>SYNC, Data, Address, R/W, ML, VP, M/X, E, VDA, VPA,<br>$\phi$ 1 (OUT), $\phi$ 2 (OUT)                                  | Vol        |                   | 0.4                    | v              |
| Supply Current (No Load)                                                                                                                                           | IDD        |                   | 4                      | mA/MHz         |
| Standby Current (No Load, Data Bus =Vss or Vod<br>RES, NMI, IRQ, SO, BE, ABORT, ¢2 = Vod)                                                                          | ISB        | -                 | 10                     | μA             |
| Capacitance (VIN = 0V, TA = 25°C, f = 2 MHz)<br>Logic, $\phi$ 2 (IN)<br>Address, Data, R/W (Off State)                                                             | Cin<br>Cts |                   | 10<br>15               | pF<br>pF       |

# VL86C010



# 32-BIT REDUCED INSTRUCTION SET COMPUTER

# FEATURES

- 32-bit internal architecture •
- 32-bit external data bus
- 64M-byte linear address space
- Bus timing optimized for standard DRAM usage with page mode operation
- 32M-byte/second bus bandwidth
- Simple, powerful instruction set providing an excellent high-level language compiler target
- Hardware support for virtual memory systems
- Low interrupt latency for real-time application requirements
- Full CMOS implementation results in low power consumption
- Single 5 V ± 5% operation
- 84-pin JEDEC Type-B leadless chip carrier or plastic leaded chip carrier (PLCC)

# DESCRIPTION

The VL86C010 Acorn RISC Machine (ARM) is a full 32-bit general-purpose microprocessor designed using reduced instruction set computer (RISC) methodologies. The processor is targeted for the microcomputer. graphics, industrial, and controller markets for use in stand-alone or embedded systems. Applications in which the processor is useful include laser printers, graphics engines, N.C. machines, and any other systems requiring fast real-time response to external interrupt sources and high processing throughput.

The VL86C010 features a 32-bit data bus, 25 registers of 32 bits each, a load-store architecture, a partially overlapping register set. 3 us worstcase interrupt latency, conditional instruction execution, a 26-bit linear address space, and an average instruction execution rate of from three to four million instructions per second (MIPS). Additionally, the processor supports two addressing modes: program counter (PC) and base register relative. The ability to do preand post-indexing allows

stacks and queues to be easily implemented in software. All instructions are 32 bits long (aligned on word boundaries), with register-toregister operations executing in one cycle. The two data types supported are 8-bit bytes and 32-bit words.

Using a load-store architecture simplifies the execution unit of the processor, since only a few instructions deal directly with memory and the rest operate register-toregister. Load and store multiple register instructions provide enhanced performance, making context switches faster and exploiting sequential memory access modes.

The processsor supports two types of interrupts that differ in priority and register usage. The lowest latency is provided by the fast interrupt request (FIRQ), which is used primarily for I/O to peripheral devices. The other interrupt type (IRQ) is used for interrupt routines that do not demand low-latency service or where the overhead of a full-context switch is small compared with the interrupt process execution time.

## **PIN DIAGRAM**

JEDEC Type-B Ceramic Leadless Chip Carrier



| ORDER INFORMATION |                    |                                |  |
|-------------------|--------------------|--------------------------------|--|
| Part<br>Number    | Clock<br>Frequency | Package                        |  |
| VL86C010-04QC     |                    | Plastic Leaded<br>Chip Carrier |  |
| VL86C010-04LC     |                    | JEDEC Type-B                   |  |

| VL86C010-04LC | sta<br>Sta | Ceramic Carrier                 |
|---------------|------------|---------------------------------|
| VL86C010-08QC | 0 1411-    | Plastic Leaded<br>Chip Carrier  |
| VL86C010-08LC | 8 MHZ      | JEDEC Type-B<br>Ceramic Carrier |

Note: Operating temperature range: 0°C to +70°C.



# **BLOCK DIAGRAM**





# SIGNAL DESCRIPTIONS

| Signal<br>Nam <del>e</del> | Pin<br>Number<br>(1)         | Signal<br>Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|----------------------------|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Ø1,Ø2                      | 2,1                          | Processor Clock Ø1 and Ø2 Inputs - These two inputs provide the clock to the circuit. In<br>order to minimze clock skew, these inputs are not buffered internally and therefore must<br>swing monotonically between GND and VCC without overshoot. The clocks must be<br>non-overlapping and should be driven directly by 74HCXX outputs.                                                                                                                                                                                                                                                                                                                                                         |  |
| IRQ                        | 7                            | interrupt Request input - This is the normal interrupt request pin. It may be asserted asynchronously to cause the processor to be interrupted. It is active LIW.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| FIRQ                       | 8                            | Fast Interrupt Request Input - This interrupt request line has a higher priority than $\overline{IRQ}$ , but otherwise is the same. It, too, is active LOW.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
| RESET                      | 9                            | Reset Input - This is the reset signal for the processor. While active, the processor will<br>execute no-ops until the signal goes inactive, from which point execution starts at the<br>reset vector location. This signal is active HIGH.                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
| ABORT                      | 6                            | Abort Input - This signal can be used to abort the current bus cycle being executed by the<br>processor. Typically it is connected to a memory management unit to control accesses<br>for protection. The abort signal is active HIGH.                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| D0 - D31                   | 46 - 53,<br>56 - 74, 77 - 81 | Data 0 - Data 31 - This is the 32-bit bi directional data bus used to transfer data to and from the memory. These lines are three-state and active HIGH.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
| DBE                        | 83                           | Data Bus Enable Input - This is the asynchronous three-state control signal for controlling<br>the drivers of the data bus. When asserted, the data bus is enabled. This signal is active<br>HIGH.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| Б/W<br>M0, M1              | 84<br>14, 13                 | Byte / Word Output - This early warning signal (note 2) indicates to the memory system that the current fetch is a byte, rather than a word, fetch. It is asserted during the last portion of the cycle preceding the cycle that will require a byte fetch. When asserted (LOW) the memory system should deal with bytes. It is active LOW. Mode 0, 1 Outputs - These two signals are used to indicate the current operating mode of the processor. They can be used as address space modifiers to increase the address space, or to assist a memory management unit in offering various protection modes. The lines exp active LOW and the inverse of bits 0.1 of the processor active register. |  |
|                            |                              | Mo     MT     MODE       0     0     Supervisor       1     0     FIRQ       1     1     USER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
| A0 - A25                   | 44 - 34,<br>31 - 11          | Address 0 - Address 25 Outputs - These are the 26 address lines. A0 and A1 are byte addresses and should be ignored except during byte memory cycles. During word transfers the current mode value will appear on these signals. The address lines are three-state and active HIGH.                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| ABE                        | 45                           | Address Bus Enable Input - This is the asynchronous tri-state control signal for controlling the drivers of the address bus. When asserted the address bus is enabled. The signal is active high.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| ALE<br>the                 | 16                           | Address Latch Enable Input- This signal is used to control internal transparent latches on the address outputs. When ALE is HIGH, the address outputs change during phase 2 to value required for the next cycle. Direct interfacing to ROMs requires address lines to be stable until the end of phase 2. Holding ALE LOW until the end of phase 2 will latch the address outputs for ROM cycles. Systems that do not directly interface to ROMs may tie ALE HIGH.                                                                                                                                                                                                                               |  |



# SIGNAL DESCRIPTIONS

| Signal<br>Name | Pin<br>Number<br>(1) | Signal | Description                                                                                                                                                                                                                                                                                          |
|----------------|----------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ₩.             | 3                    |        | R/W Output - This is the read / write signal from the processor. When asserted (LOW) it<br>indicates that the processor is performing a read operation. When negated, (HIGH) the<br>processor is performing a write operation. This signal is an early warning signal (note 2)<br>and is active LOW. |
| MREQ           | 5                    |        | Next Memory Cycle Start Output - This is an early warning indicator (note 2) that is<br>asserted before the processor will start a memory cycle during the next clock phase. This<br>signal is active LOW.                                                                                           |
| TRANS          | 10                   |        | Translate Enable Output - This signal, when asserted by the processor, tells a memory<br>management unit that translation should be done on the current address. When negated it<br>indicates that the address should pass through untranslated. This signal is active LOW.                          |
| OPC            | 4                    |        | Instruction Fetch Output - This early warning signal (note 2), when asserted, indicates that the current bus cycle is an instruction fetch. This signal is active LOW.                                                                                                                               |
| SEQ            | 15                   |        | Next Address Sequential Output- This early warning signal (note 2) is asserted when the processor will generate a sequential address during the next memory cycle. It may be used to control fast memory access modes. This signal is active HIGH.                                                   |

### Notes:

1 Pin numbers are for JEDEC Type-B leadless chip carrier only.

2 Early warning signals are asserted during the last portion of the cycle preceding the cycle for which they will be used.

# **FUNCTIONAL PINOUTS**



# FUNCTIONAL DESCRIPTION

The philosophy of RISC processor design is based on the idea that some processing functions can be moved from hardware to software, with the result that the simplified hardware can actually execute functions in software faster than with complicated hardware. Analysis done several years ago at major research centers has shown that a processor and compiler combination can replace the traditional processoralone architectures. One of the sad historical facts of the 16-bit processor world is that, after chip designers spent many man-months figuring out how to implement universally acceptable complicated instructions to do such things as link to a subroutine, few compiler writers actually took advantage of these complex instructions. In fact, most compilers only use a fraction of the instructions and addressing modes of traditional computer architectures.

In addition, the customer pays dearly for the unused silicon required to implement these instructions. The customer pays for the inefficient utilization in both cost of the processor and in lower performance since the silicon spent for complex instruction decoding and micro-sequencing could have been used for additional pipelining. larger register sets, or other specialpurpose hardware that can be used efficiently. If the addition of a new instruction causes all instructions to execute 10% slower due to internal processor delays, the new instruction had better be used more than 10% of the time, otherwise overall performance has been sacrificed. This makes an argument for simple performanceoriented architectures that are more dependent on compiler technology to implement less frequently used instructions.

### A BETTER MEASURE OF PERFORMANCE

Inherent in the concept of RISC processors is the notion that more instructions are required to implement the same functions than could be done by fewer instructions with a complex instruction set computer (CISC) processor. In most cases, even when more instructions are needed by RISC processors, the function can still be performed more quickly on RISC processors than CISC processors. This is causing the industry to doubt the million instruction per second (MIPS) ratings of RISC processors for good reason. The term MIPS is often used exclusively as a means of benchmarking performance. A better measure of performance is to time actual execution of real-world problems, independent of the number of instructions required to implement the function. An important parameter to keep constant when benchmarking processors is the memory access times, since not all processors will meet performance claims when working with commodity memories.

Another traditional measure of performance in the microprocessor world is the clock frequency of the processor. " Faster is better" has been the rule of thumb, but the most important consideration is the average number of bus cycles per instruction. A processor with a low clock frequency and a low number of bus cycles per instruction can actually outperform a processor with a high clock frequency and a higher number of bus clock cycles per instruction. The best choice of



processors is one that benchmarks high while using a relatively low clock frequency and a small number of clocks per instruction executed. The VL86C010 possesses these characteristics giving it the best future evolution path to exploit advances in process technology.

### **PROGRAMMING MODEL**

The VL86C010 contains a large, partially overlapping set of 25 32-bit registers, although the programmer can access only 16 registers in any mode of operation. Fifteen of the registers are general-purpose, with the remaining ten dedicated to such functions as user mode, FIRQ mode, IRQ mode, supervisor mode and the program counter / processor status register. Figure 1 shows the register model of the VL86C010. Registers R0 to R13 are accessible from the user mode for any purpose. The fifteenth register, user mode return-link, is specific to the user mode. Its contents are mapped with those of other return-link registers as the mode is changed. The return-link register is used by the Branch-and-Link instruction in a procedure call sequence, but may be used as a generalpurpose register at other times. The least significant two bits of the processor status word (PSW) define the current mode of operation.







Five registers are dedicated to the FIRQ mode and overlay user mode R10 to R14 when the fast interrupt request is serviced. The registers R10 FIRQ to R13 FIRQ are local to the fast interrupt service routine and are used instead of the user mode registers R10-R13, R14 FIRQ holds the address used to restart the interrupted program, instead of pushing it onto a stack at the expense of another memory cycle. Using a link register helps provide very fast servicing of I/O-related interrupts, without disturbing the contents of the general-purpose register set, although the FIRQ routine can access the R0 to R9 user-mode registers if desired. The FIRQ mode is typically used for very short interrupt service routines that might fetch and store characters in a disk or tape controller application.

The next two registers are dedicated to the IRQ mode and overlay user mode R13 and R14 when the IRQ is serviced. Once again, R14 IRQ is the return-link register that holds the restart address and R13 IRQ is general-purpose and dedicated to the IRQ mode. This mode is used when the interrupt service routine will be lengthy and the overhead of saving and reloading the register set will not be a significant portion of the overall execution time.

Two registers are dedicated to the supervisor mode and overlay user mode R13 and R14 when a supervisor mode switch is made using a SWI instruction. Operation of these two registers is the same as previously discussed.

The last register (R15) contains the processor status word and program counter and is shared by all modes of operation. The upper six bits are processor status, the next 24 bits are the program counter (word address), and the last two indicate the mode.

### PROCESSOR STATUS REGISTER

Like most 32-bit processors the VL86C010 makes a distinction between user and supervisor modes: the user executes at the lowest privilege level, and the supervisor interrupts executes at higher levels of privilege. Figure 2 shows the processor status



word containing the control line states associated with each mode.

Translate is a control signal provided by the processor for control of an external memory management unit. The translate line is enabled in the user mode and disabled in the supervisor, fast interrupt, and normal interrupt modes, since all modes except for the user mode are expected to be running secure code. Translated fetches can be made from the supervisor mode by setting an optional bit in the load / store instructions.

The processor status register contains the program counter, mode control bits, and condition codes, as shown in Figure 2. The bits marked with an asterisk are alterable only from nonuser modes. If the user tries to write to these bits, they remain unchanged and the processor continues operation in the user mode. In other words, this is not a trap condition. The flags in the processor status register are the standard Negative, Zero, Carry, and Overflow. The sixteen allowable combinations of the condition code bits are shown in Table 1. These combinations are used for all conditional instruction execution since a conditional branch is nothing more than a jump instruction with conditional execution.

### EXCEPTIONS

The VL86C010 supports a partially overlapping register set so that, when interrupts are taken, the contents of the register array does not have to be saved before new operations can begin. Improved response time is accomplished, in the case of the fast interrupt, by dedicating four general-

purpose registers, in addition to a returnlink register, that are only accessible in the FIRQ mode. These dedicated registers can contain all the pointers and byte-counts for simple I/O service routines, thus incurring no overhead when context-switching between processing and servicing interrupts at high rates. The other modes (IRQ and SUP) each have one general-purpose and one return address (link) register dedicated to them. The general-purpose register is ideally suited for implementing a local stack for each mode. The need for dedicated registers in these modes is not as great, since the time spent in an interrupt or supervisor routine is on the average much greater than the time spent in transition between the routines. The working registers can be saved and restored from stacks without significant overhead.

The interrupt latency of the VL86C010 is very short because the instruction execution time is typically 250 ns, with a maximum of 2.25 µ (for a load multiple instruction, loading sixteen registers). Once the processor recognizes an interrupt is pending, the time to begin processing is 0.5 µ, making a total worst-case interrupt latency of 2.75 µ. In addition to interrupts, six other types of exceptions are supported by the processor. These are address exceptions, data-fetch cycle aborts, instruction-fetch cycle aborts, software interrupts, undefined instruction traps, and reset.

The VL86C010 supports a 26-bit linear address space, allowing a total of 64Mbytes of physical memory. Data



### to the associated service routine, except for the FIRQ entry. In order to further reduce latency, the FIRQ service routine may begin at address 001CH if the software designer so chooses.

Whenever the processor enters the supervisor mode, whether from a SWI, address exception, undefined instruction trap, prefetch, or data abort, the IRQ is disabled and the FIRQ unchanged.

### INSTRUCTION SET

The VL86C010 supports five basic types of instructions with several options available to the programmer. These instruction types are: data processing , data transfer, block data transfer, branch, and software interrupt. All instructions contain a 4-bit conditional execution field (shown in Table 1) that can cause an instruction to be skipped if the condition specified is not true. The execution time for a skipped instruction is one sequential cycle (125 ns for an 8 MHz processor).

Data processing instructions operate only on the internal register file and each has three operand references: a destination and two source fields. The destination (Rd) can be any of the registers, including the processor status register, although some bits in R15 can only be changed in particular modes. The source operands can have two forms: both can be registers (Rm and Rn) or a register (Rn) and an 8-bit immediate value. Both forms of operand specification provide for the optional shifting of one of the source values using the on-board barrel shifter. If both operands are registers, the Rm can be

# **TABLE 1. INSTRUCTION CONDITION CODES**

| Condition | Encoded<br>Value | Operation                                                                                 |
|-----------|------------------|-------------------------------------------------------------------------------------------|
| AL        | E                | Always                                                                                    |
| cc        | з                | Carry Clear / Unsigned Lower Than                                                         |
| cs        | 2                | Carry Set / Unsigned Higher Or Same                                                       |
| EQ        | 0                | Equal ( Z Set )                                                                           |
| GE        | A                | Greater Than Or Equal $(N \cdot V) + (\overline{N} \cdot \overline{V})$                   |
| GT        | с                | Greater ((( $N \cdot V$ ) + ( $\overline{N} \cdot \overline{V}$ )) $\cdot \overline{Z}$ ) |
| н         | 8                | Higher Unsigned ( C • Z )                                                                 |
| LE        | D                | Less Than Or Equal ((( $N \cdot \overline{V}) + (\overline{N} \cdot V)$ ) + Z)            |
| LS        | 9                | Lower Or Same Unsigned ( $\overline{C} + Z$ )                                             |
| LT        | В                | Less Than (( $N \cdot \overline{V}$ ) + ( $\overline{N} \cdot V$ ))                       |
| мі        | 4                | Negative (N)                                                                              |
| NE        | 1                | Not Equal ( $\overline{Z}$ )                                                              |
| NV        | F                | Never                                                                                     |
| PL        | 5                | Positive ( N )                                                                            |
| vc        | 7                | Overflow Clear                                                                            |
| VS        | 6                | Overflow Set                                                                              |

references outside the range 0 to 3FF,FFFH cause an address exception trap that can be used to detect a runaway program. The program counter will wrap around to 0000H without causing an address exception condition.

If the abort signal is asserted by the memory management unit during a data fetch, the processor will abort data transfer instructions (LDR, STR) as if they had never been executed. If the instruction was a block data transfer (LDM, STM), the processor will allow the instructions to complete. If the writeback control bit in these instructions is set, the base address will be updated even if it would have been overwritten during the instruction execution. An example of this would be execution of a block data transfer instruction with the base register in the list of registers to be overwritten.

Software interrupt instructions (SWI) are used to change from user mode to supervisor mode. When encountered, the processor will save the current program counter (R15) into R14 SUP, set the mode bits to the supervisor mode, and start execution at the software interrupt vector address.

An undefined instruction will cause a trap similar to the execution of a software interrupt, except that the undefined instruction vector will be used as the next address.

Reset is treated similar to the other traps and will start the processor from a known address. When the reset condition is recognized, the currently executing instruction will terminate abnormally, the processor will enter the supervisor mode, disable both the FIRQ and IRQ interrupts, and begin execution at address 0000H. While the reset condition remains, the processor will execute dummy instruction fetches.

The processor exception vector map is illustrated in Figure 3. The exceptions are prioritized to reset (highest), address exception, data abort, FIRQ, IRQ, prefetch abort, undefined instruction, and software interrupt (lowest).These vector addresses normally will contain a branch instruction

### FIGURE 3. EXCEPTION VECTOR MAP

| Address(Hex) | Function                   | PriorityLevel |
|--------------|----------------------------|---------------|
| 000 0000     | Reset                      | 0             |
| 000 0004     | Undefined Instruction Trap | 6             |
| 000 0008     | Software Interrupt         | 7             |
| 000 000C     | Abort (Prefetch)           | 5             |
| 000 0010     | Abort (Data)               | 2             |
| 000 0014     | Address Exception          | 1             |
| 000 0018     | Normal Interrupt (IRQ)     | 4             |
| 000 001C     | Fast Interrupt (FIRQ)      | 3             |



# **TABLE 2. DATA PROCESSING INSTRUCTIONS**

| Instruction | Function                    | Op Code | Operation            | Flags<br>Affected |
|-------------|-----------------------------|---------|----------------------|-------------------|
| ADC         | Add With Carry              | 5       | Rd:=Rn+Shift(S2)+C   | N, Z, C, V        |
| ADD         | Add                         | 4       | Rd:=Rn+Shift(S2)     | N, Z, C, V        |
| AND         | And                         | 0       | Rd:= Rn • Shift(S2)  | N, Z, C           |
| BIC         | Bit Clear                   | Е       | Rd:= Rn • Shift(S2)  | N, Z, C           |
| CMN         | Compare Negative            | в       | Shift(S2)+Rn         | N, Z, C, V        |
| CMP         | Compare                     | A       | Rn-Shift(S2)         | N, Z, C, V        |
| EOR         | Exclusive OR                | 1       | Rd:=Rn⊕ Shift(S2)    | N, Z, C           |
| MOV         | Move                        | D       | Rd:=Shift(S2)        | N, Z, C           |
| MVN         | Move Negative               | F       | Rd:=Shift(S2)        | N, Z, C           |
| ORR         | Inclusive OR                | С       | Rd:=Rn+Shift(S2)     | N, Z, C           |
| RSB         | Reverse Subtract            | 3       | Rd:=Shift(S2)-Rn     | N, Z, C, V        |
| RSC         | Reverse Subtract With Carry | 7       | Rd:=Shift(S2)-Rn-1+C | N, Z, C, V        |
| SBC         | Subtract With Carry         | 6       | Rd:=Rn-Shift(S2)-1+C | N, Z, C, V        |
| SUB         | Subtract                    | 2       | Rd:=Rn-Shift(S2)     | N, Z, C, V        |
| TEQ         | Test For Equality           | 9       | Rn   Shift(S2)       | N, Z, C           |
| TST         | Test Masked                 | 8       | Rn • Shift(S2)       | N, Z, C           |

shifted. For the other case, it is the immediate value that can pass through the shifter. Another field in these instructions allows for the optional updating of the condition codes as a result of execution of the operation. Table 2 shows the possible data processing operations and the status flags affected.

Data transfer instructions are used to move data between memory and the register file (load), or vice-versa (store). The effective address is calculated using the contents of the source register (Rn) plus an offset of either a 12-bit immediate value or the contents of another register (Rm). When the offset is a register, it can optionally be shifted before the address calculation is made. Table 3 shows the addressing modes supported and their corresponding assembler syntax. The offset may be added to or subtracted from index register Rn. Incrementing or decrementing can be either pre- or postindexing, depending on the desired addressing mode. In the post-indexed mode, the transfer is performed using the contents of the index register as the effective address, and the index register is modified by the offset and rewritten. In the pre-indexed mode, the effective address is the index register modified in the appropriate manner by the offset. The modified index register

can be written back to Rn, if the writeback bit is set (or left unchanged, if desired). When a register is used as the offset, it can be pre-scaled by the barrel shifter in a similar manner, as with data processing instructions.

Data transfer instructions can manipulate bytes or words in memory. When a byte is read from the memory, it is placed in the low-order 8 bits of the register and zero-extended to a full word. For byte writes, the lower 8 bits of the register are written to the byte address referenced and the other bytes within the word unaffected.

The VL86C010 supports both logical and physical address spaces at a lower level in hardware than other processors. Data transfer instructions contain a translate enable bit that allows non-user mode programs to select the logical or physical address space as desired. The bit from the instruction is placed on the TRANS pin of the processor to signal an external memory management unit (MMU) whether to translate first or pass the address from the processor bus to the memory. This allows programs executing in the supervisor or interrupt modes to have easy access to user memory areas for page fault correction or to have bounds checking performed on dynamic data structures in the system space by the MMU. In the user mode, addresses are always translated by the MMU if it is implemented in the system.

The block data transfer instructions allow multiple registers to be moved in a single instruction. The instruction has a field containing a bit for each of the sixteen registers visible in the current mode. Bit 0 corresponds to R0, and bit 15 corresponds to R15, the program counter. A bit set in a particular position means that the corresponding register will be affected by the transfer. The register bits are always saved from lowest to highest and R0 will always appear at a lower address than R1. The ability to pre- or post- increment or decrement allows both stacks and queues to be implemented efficiently with any convention chosen by the programmer.

The branch instruction has two forms, branch and branch-with-link. The branch instruction causes execution to start at the current program counter plus a 24bit offset contained in the instruction.

## TABLE 3. MEMORY ADDRESSING MODES

| AddressingMode                               | Operation                                                   | Syntax   |
|----------------------------------------------|-------------------------------------------------------------|----------|
| PC Relative                                  | EA* = PC ± Offset ( 12 Bits )                               | LABEL    |
| Base Register Offset<br>With Post-Increment  | EA <sup>+</sup> = Rn<br>Rn±Offset ─► Rn                     | [Rn],Off |
| Base Register Offset<br>With Pre-Increment** | EA <sup>*</sup> = Rn ± Offset (12 Bits)<br>Rn ± Offset → Rn | [Rn,Off] |
| Base Register Index<br>With Post-Increment   | EA* = Rn<br>Rn±Rm ─► Rn                                     | [Rn],Rm  |
| Base Register Index<br>With Pre-Increment**  | EA* = Rn ± Rm<br>Rn ± Rm → Rn                               | [Rn,Rm]  |

- Effective Address

\*\* - Program control of index register update, i.e. Rn may be left unchanged.

The offset is left-shifted by re two bits (forming a 26 bit address) (N before it is added to the program be counter. Since all instructions are Th word-aligned a branch can reach any is location in the address space. The ca branch-with-link instruction copies the program counter and processor status Th register into R14 prior to branching to loc the new address. Returning from the su

reloading the program counter from R14 (MOV PC,R14). The PSR can optionally be restored from R14 (MOVS PC,R14). The software interrupt instruction format is used primarily for supervisor service calls. When this instruction is executed the PC and PSR are saved in R14 SUP. The PC is then set to the SWI vector location and the processor placed in the supervisor mode.

Instructions operate at speeds that are

# TABLE 4. INSTRUCTION EXECUTION TIMES

| Operation  | Base Execution<br>Time | Adjustment for<br>Source Shift | Adjustment for PC<br>Modification |
|------------|------------------------|--------------------------------|-----------------------------------|
| RS∙#-► RD  | 18                     | 1S for Shift(RS)               | 1S + 1N if PC Modified            |
| RS+RS-► RD | 18                     | 1S for Shift(RS)               | 1S + 1N if PC Modified            |
| LDR        | 2S + 1N                | 1S for Shift(RS)               | 1S + 1N if PC Modified            |
| STR        | 2N                     | 1S for Shift(RS)               |                                   |
| LDM        | ( n* + 1 )S + 1N       |                                | 1S + 1N if PC Modified            |
| STM        | ( n* - 1 )S + 2N       |                                |                                   |
| BR         | 2S + 1N                |                                |                                   |
| BR & LINK  | 2S + 1N                |                                |                                   |
| SWI        | 2S + 1N                |                                |                                   |

\* n - the number of registers transferred in a Load /Store Mutiple nstruction. If the condition field in an instuction is not true, the instruction is skipped and the execution time is 1S cycle.

# VL86C010

dependent upon the options selected. Table 4 shows the instruction types. execution rates and adjustments for operand shifting or affecting the program counter. The table is expressed in terms of N and S cycles, representing non-sequential and sequential cycles, respectively. The processor is able to take advantage of memories that have faster access times when accessed sequentially in the nibble or column mode. These faster cycles are designated as S cycles, while the N cycles typically take twice as long. If faster static memory is used, the N and S cycles would be equal.

The VL86C010 is offered in two packages, an 84-pin JEDEC Type-B ceramic leadless chip carrier and an 84pin plastic leaded chip carrier (PLCC) for lower cost applications. The JEDEC Type-B package requires a suitable socket for mounting the carrier onto a printed circuit board. The PLCC package can be either surface-mounted directly onto the board or socketed with currently available standard sockets, depending on manufacturing requirements and/or capabilities.

## PIN DIAGRAM

Plastic Leaded Chip Carrier

branch-with-link simply involves



3-49



# **ABSOLUTE MAXIMUM RATINGS**

| Ambient Operating<br>Temperature      | -10 to +80°C        |
|---------------------------------------|---------------------|
| Storage Temperatu                     | re -65 to + 150°C   |
| Supply Voltage to<br>Ground Potential | -0.5 to VCC + 0.3 V |
| Applied Output<br>Voltage             | -0.5 to VCC + 0.3 V |
| Applied Input<br>Voltage              | -0.5 to + 7.0 V     |
| Power Dissipation                     | 2.0 W               |

Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only. Functional operation of this device at these or other conditions above those indicated in the operational sections of this specification is not implied and exposure to absolute maximum rating conditions for extended periods may affect device reliability.

# **DC CHARACTERISTICS** TA = 0°C to +70°C, VCC = 5 V $\pm$ 5%

| Symbol | Parameter                                 |            | Min     | Тур | Max        | Unit   | Conditions                                                                                                     |
|--------|-------------------------------------------|------------|---------|-----|------------|--------|----------------------------------------------------------------------------------------------------------------|
| VOH    | Output High Voltage<br>Output Low Voltage |            | VCC-0.5 | -   | VCC<br>0.4 | V<br>V | IOH = -3.0 mA<br>IOL = 3.6 mA                                                                                  |
| VOL    |                                           |            |         |     |            |        |                                                                                                                |
| VIH    | loout Llich veltere                       | Ø1, Ø2     | VCC-0.3 |     | VCC+0.3    | v      | provide a second se |
|        | Input High voltage                        | All Others | 2.4     |     | VCC+0.3    | V      |                                                                                                                |
|        | Input Low Voltage                         | Ø1, Ø2     | -0.3    |     | 0.3        | V      |                                                                                                                |
|        |                                           | All Others | -0.3    |     | 0.8        | V      |                                                                                                                |
| ILI    | Input Leakage Current                     |            |         |     | 10         | μA     | VIN = 0V to VCC                                                                                                |
| ILO    | Output Leakage Current                    |            |         |     | 10         | μA     | VOUT = 0V to VCC                                                                                               |
| ICC    | Operating Supply Current                  |            |         | 20  |            | mA     | See Note 3                                                                                                     |
| IOS    | Output Short Circuit                      | Current    |         |     | TBD        | mA     |                                                                                                                |

# CAPACITANCE TA = 25°C, f = 1.0 MHz

| Symbol | Parameter          | Min | Мах | Unit | Conditions              |
|--------|--------------------|-----|-----|------|-------------------------|
| CI     | Input Capacitance  |     | TBD | pF   | VIN = 0 V - See Note 4  |
| со     | Output Capacitance |     | TBD | pF   | VOUT = 0 V - See Note 4 |

Notes:

1 Measured with outputs unloaded.

2 Periodically sampled as opposed to 100% tested.



# AC CHARACTERISTICS TA = 0°C to +70°C, VCC = 5 V±5%

|        |                       | VL8  | 6C010 - | 4     | VL86C010 - 8 |      |       |       |                       |
|--------|-----------------------|------|---------|-------|--------------|------|-------|-------|-----------------------|
| Symbol | Parameter             | Min. | Тур.    | Max.  | Min.         | Тур. | Max.  | Units | Conditions            |
| тν     | Clock Non-Overlap     | 0    |         |       | 0            |      |       | ns    | Measured at 2 V Point |
| TCLK   | Clock Period          | 250  |         | 10000 | 125          |      | 10000 | ns    |                       |
| TCKL   | Clock Low Time        | TBD  | 125     | 10000 | TBD          | 62.5 | 10000 | ns    |                       |
| тскн   | Clock High Time       | TBD  | 125     | 10000 | TBD          | 62.5 | 10000 | ns    |                       |
| TAOUT  | Address Delay Time    |      |         | 0     |              |      | 0     | ns    |                       |
| TAH    | Address Hold Time     |      | 10      | TBD   |              | 10   | TBD   | ns    |                       |
| TRWS   | R/W Setup Time        | 0    |         | TBD   |              | 0    | TBD   | ns    |                       |
| TRWH   | R/W Hold Time         |      | 10      | TBD   |              | 10   | TBD   | ns    |                       |
| TDOUT  | Data Out Delay Time   |      |         | 100   |              |      | 50    | ns    |                       |
| TDOH   | Data Out Hold Time    |      | 10      | TBD   |              | 10   | TBD   | ns    |                       |
| TDIS   | Data In SetupTime     | 10   |         | · · · | 10           |      |       | ns    |                       |
| TDIH   | Data In Hold Time     | 20   |         |       | 20           |      |       | ns    |                       |
| TDBE   | Data Bus Enable Time  |      | 60      |       |              | 30   |       | ns    |                       |
| TDBZ   | Data Bus Disable Time |      | 70      |       |              | 35   |       | ns    |                       |
| TABTS  | Abort Setup Time      | 70   |         |       | 35           |      |       | ns    |                       |
| TABTH  | Abort Hold Time       | 0    |         | TBD   | 0            |      | TBD   | ns    |                       |
| TSEQD  | Sequential Delay Time |      |         | 110   |              |      | 55    | ns    |                       |
| TSEQH  | Sequential Hold Time  |      | · · · · | 10    |              |      | 10    | ns    |                       |

# AC TEST CONDITIONS



# AC TEST LOAD CIRCUIT





TIMING DIAGRAMS PROCESSOR CLOCKS



### MINIMUM BUS CYCLE



3-52



# TIMING DIAGRAMS

DATA BUS ENABLE



### **EXAMPLES OF THE INSTRUCTION SET**

The following examples illustrate methods that basic ARM instructions can be combined to yield efficient code. None of the methods saves a large amount of execution time, although they all save some; most result in more compact code.

### EXAMPLE 1 - USING THE CONDITIONAL EXECUTION FOR THE LOGICAL OR FUNCTION.

| CMP | Rn, #p |
|-----|--------|
| BEQ | Label  |
| CMP | Rm, #q |
| BEQ | Label  |

; IF Rn = p OR Rm = q THEN ; GOTO Label

By using conditional execution, the routine compresses to:

| CMP   | Rn, #p |                                     |
|-------|--------|-------------------------------------|
| CMPNE | Rm, #q | ; if Rn not equal p, try other test |
| BEQ   | Label  |                                     |

### EXAMPLE 2 - ABSOLUTE VALUE

| TEQ   | Rn, #0     | ; check sign                     |
|-------|------------|----------------------------------|
| RSBMI | Rn, Rn, #0 | ; and 2's complement if required |

### **EXAMPLE 3 - UNSIGNED 32-BIT MULTIPLY**

| , 611161 ¥ | MOV   | Bm #0          | init regult register         |
|------------|-------|----------------|------------------------------|
|            |       | 1111, #0       | , init result register       |
| LOOP       | MOVS  | Ra, Ra, LSR #1 |                              |
|            | ADDCS | Rm, Rm, Rb     |                              |
|            | ADD   | Rb, Rb, Rb     |                              |
|            | BNE   | LOOP           | ; stops when Ra becomes zero |
|            |       |                | ; Rm = Ra * Rb               |
|            |       |                | ; (Ra = 0, Rb is altered)    |

### EXAMPLE 4 - MULTIPLICATION BY 4, 5, OR 6 AT RUN TIME

| MOV   | Rc, Ra, LSL #2 | ; multiply by 4          |
|-------|----------------|--------------------------|
| CMP   | Rb, #5         | ; test multiplier value  |
| ADDCS | Rc, Rc, Ra     | ; complete multiply by 5 |
| ADDHI | Rc, Rc, Ra     | ; complete multiply by 6 |

### EXAMPLE 5 - MULTIPLICATION BY CONSTANT 2^N USING THE BARREL SHIFTER (1, 2, 4, 8, 16, 32, ...)

MOV Ra, Ra, LSL #n



### EXAMPLE 6 - MULTIPLICATION BY CONSTANT (2^N)+1 USING THE BARREL SHIFTER (3,5,9,17, ...)

ADD Ra, Ra, LSL #n

### EXAMPLE 7 - MULTIPLICATION BY CONSTANT (2^N) - 1 (3, 7, 15, ...)

RSB Ra, Ra, Ra, LSL #n

### EXAMPLE 8 - MULTIPLICATION BY 6

| ADD | Ra, Ra, Ra, LSL #1 | ; multiply by 3 |
|-----|--------------------|-----------------|
| VOM | Ra, Ra, LSL #1     | ; and then by 2 |

### EXAMPLE 9 - MULTIPLY BY 10 AND ADD EXTRA NUMBER (DECIMAL TO BINARY CONVERSION)

| ADD | Ra, Ra, Ra, LSL #2 | ; multiply by 5                       |
|-----|--------------------|---------------------------------------|
| ADD | Ra, Rc, Ra, LSL #1 | ; multiply by 2 and add in next digit |

### **EXAMPLE 10 - DIVISION AND REMAINDER**

| ; enter wi | th numbe | rs in Ra and Rb    |                                       |
|------------|----------|--------------------|---------------------------------------|
|            | MOV      | Rcnt, #1           | ; bit to control the division         |
| DIV1       | CMP      | Rb, Ra             | ; move Rb until greater than Ra       |
|            | MOVCC    | Rb, Rb, ASL #1     | • • • • • • • • • • • • • • • • • • • |
|            | MOVCC    | Rcnt, Rcnt, ASL #1 |                                       |
|            | BCC      | DIV1               |                                       |
|            | MOV      | Rc, #0             |                                       |
| DIV2       | CMP      | Ra, Rb             | ; test for possible subtraction       |
|            | SUBCS    | Ra, Ra, Rb         | subtract if valid                     |
|            | ADDCS    | Rc, Rc, Rcnt       | ; put relevant bits in result         |
|            | MOVS     | Rcnt, Rcnt, LSR #1 | ; shift control bit                   |
|            | MOVNE    | Rb, Rb, LSR #1     | ; halve unless finished               |
|            | BNE      | DIV2               |                                       |
|            |          |                    | ; result in Rc                        |
|            |          |                    | ; remainder in Ra                     |
|            |          |                    | · ·                                   |

VL82C389 PRELIMINARY



# MESSAGE - PASSING COPROCESSOR (MULTIBUS® II)

# FEATURES

- Full-function, single-chip interface to Parallel System Bus ( iPSB )
- Implements full message-passing protocol on iPSB bus
- Offloads managing iPSB bus arbitration, transfer and exception cycles from iocal CPU
- Compatible with Bus Arbiter/ Controller (BAC) and Message Interrupt Controller (MIC) interface designs
- Maximizes performance on iPSB bus and local on-board bus
- Simplifies highly functional interconnect space implementations for both local and iPSB buses
- Processor-independent interface to iPSB bus
- Supports co-existence of dual-port and message-passing architectures

<sup>®</sup> MULTIBUS is a registered trademark of Intel Corp.

# **BLOCK DIAGRAM**

# FUNCTIONAL DESCRIPTION

The VL82C389 Message Passing Coprocessor (MPC) provides a highintegration interface solution for the Parallel System Bus ( iPSB ) of the MULTIBUS II architecture. The device integrates the logic necessary to implement a full bus interface solution, including support for message passing and interconnect spaces, as well as memory and I/O references on the iPSB bus. In addition, the MPC is designed to simplify implementation of dual-port memory functions for those designs that must co-exist with message passing.

The message address space in the MULTIBUS II architecture has been defined to provide a high-performance interprocessor communication mechanism for multiprocessor systems. By performing the message space interface, the VL82C389 MPC offloads the interprocessor communication tasks from the local on-board CPU, which decouples the local bus activities from the iPSB bus activities. Decoupling

these two functions eliminates an interface bottleneck present in traditional dual-port architectures. The bottleneck is a result of having a dualport architecture that requires a tight coupling between a processor and some shared memory resource of limited size. Unfortunately, as the number of processors increases, the dual-port structure degradates system performance even more dramatically.

Using the MPC component to decouple these resources yields several enhancements to system performance. For example, resources on the local processor bus and parallel system bus are not held in wait states while arbitration for other resources is performed. In addition, each transfer can occur at the full bandwidth of the associated bus. The benefit of this is the increased overall system performance that results from processors being able to process other tasks in parallel, with message transfers being handled by the MPC component.



# ORDER INFORMATION

| Part<br>Number | Package                            |
|----------------|------------------------------------|
| VL82C389-GC    | Ceramic Pin<br>Grid Array<br>(PGA) |

**Note:** Operating temperature range: 0°C to 70°C.

# VL82C389 PRELIMINARY

# FUNCTIONAL DESCRIPTION

#### Arbitration, Transfer, and Exception Cycle Protocol Support

The Message-Passing Coprocessor component implements the full arbitration, transfer, and exception cycle protocols required to interface to the iPSB bus. Arbitration is supported for both normal fairness mode and high priority mode.

The MPC component performs the handshake protocols necessary to successfully complete iPSB transfer operations. Transfer operations include access to memory, I/O, message and interconnect address spaces on the iPSB bus. During the transfer cycle, the device generates and checks parity on the System Control (SC) lines and on the Address/Data (AD) lines. In addition, the MPC component recognizes agent errors and bus exceptions that are reported to the local CPU for recovery action.

### INTERFACE DESCRIPTION

This section describes each interface noted in the block diagram on the front page. These interfaces include the local bus, the iPSB bus, the interconnect bus, and dual-port memory.

### The Local Bus Interface

The local bus interface is used to provide a processor-independent path from the on-board CPU to the iPSB bus. This interface supports direct references (memory, I/O, and interconnect address spaces) to the iPSB bus, references to local on-board interconnect space, and the full protocol for unsolicited and solicited message operations to/from the on-board CPU. Within the MPC component, local bus interface support consists of three logical interfaces: register, reference, and DMA. The register interface is used for message operations and access to interconnect address register on-board. These operations are completed fully asynchronous to the bus clock or interconnect bus operations. The reference interface is used to access resources asynchronous to the CPU (local interconnect space and memory, I/O, and interconnect address spaces on the iPSB bus). The DMA interface is used to transfer data for solicited message operations. This interface is designed to allow either two-cycle or single-cycle transfers. Single-cycle

transfers allow direct transfer of data between the MPC component and memory. To achieve higher performance via single-cycle transfers, the DMA interface is optimized for aligned data structures; however, operation on arbitrary byte strings is also supported.

### **iPSB Bus Interface**

The iPSB bus interface implements a full 32-bit interface to the iPSB bus. This implementation includes arbitration. requestor control, replier control, and error handling functions. As a requestor, the MPC component supports references to memory. I/O. and interconnect spaces, as well as message packet transmission. As a replier, the MPC component supports interconnect space and message packet reception. In addition, this interface provides significant management services for external dual port memory. These services include: address recognition, iPSB bus replier handshake, agent error checking, and bus parity generation and checking. Although this device handles the majority of errors, the dual-port memory controller is still responsible for generation and check of memory data parity (not bus parity).

### Interconnect Bus Support

Simply stated, the interconnect address space provides a physical addressing mechanism (rather than logical) for software initialization and configuration of system parameters (reduces jumper configuration) and system level diagnostics. The interconnect bus provides a simple 8-bit path between the MPC component and a user-defined design for the implementation of interconnect space. All references to interconnect space (either from the local bus or the iPSB bus) are routed through this path for service. In addition, this interconnect bus can be used for nonreference related activities as diagnostics. An example of a highly functional interconnect space implementation is evidenced by the microcontroller implementation of Intel's iSBC 386/100. Further details of this implementation are available in the iSBC 386/100 Hardware Reference Manual (Intel order number: 146705-001).

Dual Port Memory Support Although the MULTIBUS II architecture has defined the message address space for optimized performance of interprocessor communication, more traditional designs can use dual-port memory implementations. The iPSB bus interface has been defined to allow coexistence of dual-port memory and message-passing architectures: however, it should be noted that the iPSB bus interface is optimized for message-passing architectures. The MPC component is designed to support this co-existence. The device can be configured to recognize a range of addresses in memory space and act as an iPSB bus replier when appropriate. If an address match is detected, the MPC component signals the external dualport memory controller of the request. While the MPC component provides an error detection and recovery mechanism for most agent errors and bus exceptions in a dual-port design, it is still the responsibility of the dual-port memory controller to generate and check memory data parity.

#### Single Board Computer Configuration The Message Passing Coprocessor component provides a processorindependent iPSB bus interface solution for intelligent SBC boards. Examples include CPU boards, intelligent peripheral controllers, file servers, intelligent data communications controllers, and graphics/image processors. This component is optimized for bus master or intelligent slave designs. Using the MPC component reduces overall board real estate required for the iPSB bus interface. The MPC component improves system reliability by performing the error checking and reporting protocols defined in the iPSB bus interface specification.

### Message Support

The MPC provides full support for unsolicited and solicited messages. For solicited messages, the MPC supports a one message deep transmit FIFO and a four message deep receive FIFO. For solicited messages, the MPC supports one output channel and one input channel. Each channel has two packet buffers to allow pipelined operations on the local and iPSB buses. These features provide the required level of support necessary to implement the high-bandwidth message-passing facility defined in the Multibus II architecture.

Unsolicited Message Support Unsolicited message support in the MPC is provided on the local bus via a register interface and on the iPSB bus

# PRELIMINARY VL82C389

with a packet transfer mechanism. An unsolicited message is initiated by the sending host CPU transferring a message to its local MPC. The transfer is performed as a series of register operations to the transmit FIFO. An unsolicited message may be from 4 to 32 bytes in length in four-byte increments. Once the unsolicited message is transferred to the MPC, the sending host is free to discard the message in memory and process another task if it so chooses. In parallel the MPC requests access to the iPSB bus for the pending transfer. Once the iPSB bus is obtained, the sending MPC transfers the message, as a single packet, to the receiving agent.

The receiving agent recognizes the incoming packet by its destination address field. If the MPC on the receiving agent detects a match between its message host ID and the destination address field, the packet is stored in a buffer and checks for error conditions. Any errors found are signaled to the sending MPC via the iPSB bus protocol.

Assuming the packet received is errorfree, the receiving host CPU is informed of the message via an interrupt signal generated by the MPC. The host responds to this interrupt by performing a series of register operations to retrieve the message from the receive FIFO.

If an error occurs during the transfer of an unsolicited message over the iPSB bus, the sending MPC takes recovery action. If the error is a NACK, the MPC retries the message a predetermined number of times. All other errors are reported back to the sending host CPU for recovery actions. The host CPU is signaled via an interrupt and can retrieve the unsolicited message, with error status, through the error FIFO. Again this operation is performed with a series of register operations.

### Solicited Message Support

Solicited message transfers can be divided into three basic phases: negotiation, data transfer, and completion. The negotiation phase of the solicited transfer requires the exchange of two special unsolicited messages between the sending and receiving agents. The buffer request message is transferred from the sending agent to the receiving agent and the buffer grant is returned from the receiving agent to the sending agent. The MPC supports the transfer of these messages with the standard transfer protocol on the iPSB bus as previously described for the typical unsolicited message.

A solicited message transfer is initiated by the sending host CPU writing a buffer request message to the sending MPC transmit FIFO. The sending MPC recognizes the message as a buffer request and saves the following information. The destination and source addresses are saved for use in the data transfer phase. The request ID is saved for identification during completion or cancel operations. The transfer length is saved to determine the end of transfer and may contain any number of bytes. The MPC will pad the transfer to an even four-byte increment on the iPSB bus.

The sending MPC then assigns a sender liaison ID and transfers the buffer request message packet on the iPSB bus. The sender liaison ID is used to bind the buffer grant ( or reject ) to its corresponding buffer request when it is received back at the sending MPC. This allows the protocol to be extended to multiple concurrent transfers in the future.

The transfer phase is handled by the sending and receiving MPCs and their DMA controllers. Neither host CPU is involved in the transfer, and each may be processing other tasks during the transfer. At the sending agent, the transfer phase is slightly overlapped with the negotiation phase. As soon as the buffer request packet is sent errorfree on the iPSB bus, the sending MPC pre-fetches up to two packets of data and prepares for transmission. Upon receiving the buffer grant and storing the necessary parameters, the data packet transfer is initiated. Data packets are then sent on the iPSB bus using full bandwidth block transfers, at intervals defined by the duty cycle parameters, until the transfer is complete. The end of transfer is signaled to the receiving MPC by the last data packet. A solicited transfer may consist of from one to 32 packets. Packets are bound to 32 bytes plus header, with total transfers limited to 16 Mbytes.

At the receiving agent, the transfer phase begins after a buffer grant packet has been sent error-free on the iPSB bus. The receiving MPC then detects data packets, verifies the liaison ID, and stores the data. If the solicited input channel is not active (e.g., due to local cancel) or the liaison ID does not match. an agent error is signaled on the iPSB bus. Errors during the transfer phase are rare. Flow control using the duty cycle parameter prevents NACK problems, and the receiver has responded with a buffer grant guaranteeing its existence and ability to perform the transfer. In the rare case that an error does occur, the MPC provides a retry algorithm for NACKs and reports exceptions or other agent errors immediately. The error is signaled to the host CPU by entering the completion phase. Errors generate an interrupt and provide error status.

The completion phase consists of a signal from the MPC to its corresponding host CPU. The signal consists of an interrupt followed by a series of register operations on the local bus. In all cases, the completion operation clears all states associated with the solicited operation in the MPC, allowing another operation to be initiated.

The MPC guarantees fail-safe operation for all aspects of the solicited message transfer, assuming the bus clock remains active (if the bus clock fails, all transfers cease, eliminating the need for recovery). This capability is provided by the error detection and reporting already discussed for bus-related problems and by two fail-safe counters that protect against fatal hardware or software errors on the sending or receiving agents. Recovery is provided to free a solicited message resouce that would otherwise be tied up indefinitely, which eliminates the need for a fail-safe software timer.

It is important to note that the fail-safe counters are not intended for normal flow control. If a receiving host CPU accumulates a significant queue of buffer requests from its MPC, it should use unsolicited messages (and possibly rejects) to free channels in the system for other uses. The fail-safe counters are only intended to replace the need for a software timer to recover from otherwise fatal hardware and software errors.

For a more comprehensive explanation of the MPC function, please refer to the Intel document, Multibus II Message Passing Coprocessor External Product Specification (Engineering Document Number: 149300-001). VL82C389 PRELIMINARY

# **PIN DIAGRAM**

Ceramic Pin Grid Array (PGA)

|   | 1           | 2             | 3             | 4             | 5               | 6               | 7               | 8            | 9               | 10            | 11            | 12            | 13            | 14          | 15          |
|---|-------------|---------------|---------------|---------------|-----------------|-----------------|-----------------|--------------|-----------------|---------------|---------------|---------------|---------------|-------------|-------------|
|   | Do          | D2            | D4            | D7            | D9              | D12             | D14             | D17          | D20             | D23           | D26           | D28           | D30           | D31         | IAD7        |
| A | 0148        | (0) 145       | <b>(</b> )143 | <b>(</b> )141 | <b>(</b> )138   | () 134          | () 133          | (0) 129      | () 125          | () 126        | <b>(</b> )121 | <b>(</b> )120 | @118          | @115        | 0111        |
|   | A5          | D1            | D3            | D6            | D8              | D11             | D13             | D16          | D19             | D22           | D25           | D27           | D29           | IAD5        | IAD6        |
| в | <b>0</b> 4  | <b>(</b> )147 | @144          | <b>(</b> )142 | <b>(</b> )139   | <b>()</b> 136   | () 135          | @128         | 0124            | <b>(</b> )122 | <b>()</b> 119 | <b>()</b> 116 | @114          | @110        | 0 107       |
|   | BE3*        | A4            | VSS           | D5            | VSS             | D10             | VCC             | D15          | D18             | D21           | D24           | vss           | IAD3          | IAD4        | IWR*        |
| с | 07          | <b>()</b> 3   | <b>(</b> )149 | 0146          | <b>()</b> 140   | <b>()</b> 137   | <b>()</b> 131   | () 130       | 0127            | <b>(</b> )123 | @117          | 0113          | <b>()</b> 109 | 0 106       | 0103        |
|   | BE2*        | A3            | A2            | VCC           | -               | -               | -               | VSS          |                 | -             | -             | vcc           | IAD1          | IAD2        | IRD*        |
| D | 9 (         | 05            | @ 2           | <b>()</b> 1   |                 |                 |                 | <b>O</b> 132 |                 |               |               | 0112          | 0108          | 0104        | 0102        |
|   | REGSEL*     | BE1*          | BE0*          | _             |                 |                 |                 |              |                 |               |               | -             | IAD0          | IAST        | IREQ*       |
| E | 012         | 0 8           | <b>6</b>      |               |                 |                 |                 |              |                 |               |               |               | <b>(</b> )105 | 0101        | 0100        |
|   | IDREQ N     | EMSEL*        | IOSEL*        |               |                 |                 |                 |              |                 |               |               |               | VSS           | BAD0*       | BAD1*       |
| F | 015         | 011           | <b>(</b> 10   |               |                 |                 |                 |              |                 |               |               |               | <b>0</b> 99   | <b>0</b> 98 | <b>9</b> 96 |
|   | ODREQ       | IDACK* C      | DACK*         |               |                 |                 |                 |              |                 |               |               |               | BAD2*         | BAD3*       | BAD4*       |
| G | 016         | <b>⊙</b> 13   | <b>(</b> 14   |               |                 |                 |                 |              |                 |               |               |               | <b>0</b> 94   | <b>0</b> 97 | <b>0</b> 95 |
|   | RD*         | WR*           | WAIT*         |               |                 |                 |                 |              |                 |               |               |               | BAD5*         | BAD6*       | BAD7*       |
| н | <b>O</b> 18 | <b>()</b> 17  | <b>()</b> 19  |               |                 |                 | тс              | P VIEW       |                 |               |               |               | <b>0</b> 93   | <b>0</b> 91 | <b>0</b> 92 |
|   | MINT        | LOCK*         | VSS           |               |                 |                 |                 |              |                 |               |               |               | BAD8*         | BAD9*       | BAD10*      |
| J | <b>O</b> 21 | O23           | <b>O</b> 20   |               |                 |                 |                 |              |                 |               |               |               | 088           | <b>0</b> 87 | O 90        |
|   | EINT        | ERR*          | COM*          |               |                 |                 |                 |              |                 |               |               |               | VSS           | BAD11* I    | BAD12*      |
| ĸ | <b>O</b> 22 | <b>0</b> 24   | O 25          |               |                 |                 |                 |              |                 |               |               |               | 084           | 085         | <b>0</b> 89 |
|   | SEL*        | BSC0*         | BSC1*         |               |                 |                 |                 |              |                 |               |               | 1             | BAD13*        | BAD14* I    | BAD15*      |
| L | <b>O</b> 26 | O 27          | <b>O</b> 31   |               |                 |                 |                 |              |                 |               |               |               | 080           | <b>0</b> 82 | 086         |
|   | BSC2*       | BSC3*         | BSC4*         | VCC           |                 |                 |                 |              |                 |               |               | VCC           | BAD16* I      | BAD17* I    | BAD18*      |
| М | 0028        | <b>O</b> 30   | <b>0</b> 34   | <b>0</b> 38   |                 |                 |                 |              |                 |               |               | 075           | 076           | 079         | <b>0</b> 83 |
|   | BSC9*       | SCDIR0        | BSC5*         | VSS           | ARB5*           | VSS R           | EFADR*          | VCC          | VSS I           | BPAR0*        | VSS           | BAD27*        | VSS           | BAD19*      | BAD20*      |
| Ν | <b>0</b> 29 | <b>⊙</b> 32   | <b>0</b> 35   | <b>O</b> 39   | O <sup>43</sup> | <b>0</b> 47     | O <sup>51</sup> | 056          | O <sup>57</sup> | <b>0</b> 62   | 065           | <b>⊙</b> 71   | 074           | 077         | <b>0</b> 81 |
|   | BSC6*       | BSC7*         | ARB1*         | ARB3*         | ARB4*           | BREQ* B         | USERR*          | LACHN        | BPAR3* I        | BPAR1*        | BAD30*        | BAD28*        | BAD25*        | BAD23*      | BAD21*      |
| Ρ | <b>0</b> 33 | <b>O</b> 36   | <b>⊙</b> 41   | <b>0</b> 42   | <b>○</b> 45     | <b>0</b> 48     | 050             | 054          | O 60            | 061           | <b>0</b> 64   | <b>0</b> 67   | <b>0</b> 69   | 072         | <b>⊘</b> 78 |
|   | BSC8*       | SCDIR1        | ARB0*         | ARB2*         | RSTNC*          | ADDIR           | TIMOUT          | BBCLK        | RESET           | BPAR2*        | BAD31*        | BAD29*        | BAD26*        | BAD24*      | BAD22*      |
| Q | <b>0</b> 37 | <b>⊙</b> 40   | <b>0</b> 44   | <b>0</b> 46   | @49             | O <sup>52</sup> | 053             | 055          | 058             | 059           | <b>0</b> 63   | <b>0</b> 66   | <b>0</b> 68   | 070         | 073         |
|   |             |               |               |               |                 |                 |                 |              |                 |               |               |               |               |             |             |

3–58

# SIGNAL DESCRIPTIONS

The MPC signals can be classified into five interface groups: the iPSB bus, the dual-port RAM, the local bus, the interconnect bus and power/ground. This table describes the individual signals for each of these interfaces.

| Signal<br>Name                                          | Pin<br>Number             | Signal<br>Description                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                              |                                                                                                 |                                                                                                             |                                                                          |                                                                                             |                                                                           |  |  |  |  |
|---------------------------------------------------------|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|--|--|--|--|
| BREQ*                                                   | 48                        | The bus reques<br>to the iPSB bus<br>access mode, t<br>to request bus a                                                                                                                           | The bus request is a bidirectional, open-drain signal with high current drive. It connects directly to the iPSB bus. As an input, it indicates that there are agents awaiting access to the bus. In fair access mode, this inhibits the MPC from activating its own request. As an output this signal is used to request bus access. Further details can be found in the iPSB bus specification.                                             |                                                                                              |                                                                                                 |                                                                                                             |                                                                          |                                                                                             |                                                                           |  |  |  |  |
| ARB0*,<br>ARB1*,<br>ARB2*,<br>ARB3*,<br>ARB4*,<br>ARB5* | 44, 41, 46, 42,<br>45, 43 | The arbitration<br>directly to the iF<br>arbitration ID of<br>these signals a<br>bus specificatio                                                                                                 | The arbitration signals are bidirectional, open drain signals with high current drive. They connect directly to the iPSB bus. These signals are used during normal operation to identify the mode and arbitration ID of an agent during arbitration cycles. During system initialization (while reset is active) these signals are used to initialize slot and arbitration IDs. Further details are available in the iPSB bus specification. |                                                                                              |                                                                                                 |                                                                                                             |                                                                          |                                                                                             |                                                                           |  |  |  |  |
| BAD0*-<br>BAD31*                                        | See Table                 | The address/data signals are bidirectional lines that connect to the iPSB bus AD* signals through 74F245 or equivalent transceivers. Further details are available in the iPSB bus specification. |                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                              |                                                                                                 |                                                                                                             |                                                                          |                                                                                             |                                                                           |  |  |  |  |
|                                                         |                           | BAD31*                                                                                                                                                                                            | BAD30*                                                                                                                                                                                                                                                                                                                                                                                                                                       | BAD29*                                                                                       | BAD28*                                                                                          | BAD27*                                                                                                      | BAD26*                                                                   | BAD25*                                                                                      | BAD24*                                                                    |  |  |  |  |
|                                                         |                           | 63                                                                                                                                                                                                | 64                                                                                                                                                                                                                                                                                                                                                                                                                                           | 66                                                                                           | 67                                                                                              | 71                                                                                                          | 68                                                                       | 69                                                                                          | 70                                                                        |  |  |  |  |
|                                                         |                           | BAD23*                                                                                                                                                                                            | BAD22*                                                                                                                                                                                                                                                                                                                                                                                                                                       | BAD21*                                                                                       | BAD20*                                                                                          | BAD19*                                                                                                      | BAD18*                                                                   | BAD17*                                                                                      | BAD16*                                                                    |  |  |  |  |
|                                                         |                           | 72                                                                                                                                                                                                | 73                                                                                                                                                                                                                                                                                                                                                                                                                                           | 78                                                                                           | 81                                                                                              | 77                                                                                                          | 83                                                                       | 79                                                                                          | 76                                                                        |  |  |  |  |
|                                                         |                           | BAD15*                                                                                                                                                                                            | BAD14*                                                                                                                                                                                                                                                                                                                                                                                                                                       | BAD13*                                                                                       | BAD12*                                                                                          | BAD11*                                                                                                      | BAD10*                                                                   | BAD9*                                                                                       | BAD8*                                                                     |  |  |  |  |
|                                                         |                           | 86                                                                                                                                                                                                | 82                                                                                                                                                                                                                                                                                                                                                                                                                                           | 80                                                                                           | 89                                                                                              | 85                                                                                                          | 90                                                                       | 87                                                                                          | 88                                                                        |  |  |  |  |
|                                                         |                           | BAD7*                                                                                                                                                                                             | BAD6*                                                                                                                                                                                                                                                                                                                                                                                                                                        | BAD5*                                                                                        | BAD4*                                                                                           | BAD3*                                                                                                       | BAD2*                                                                    | BAD1*                                                                                       | BAD0*                                                                     |  |  |  |  |
|                                                         |                           | 92                                                                                                                                                                                                | 91                                                                                                                                                                                                                                                                                                                                                                                                                                           | 93                                                                                           | 95                                                                                              | 97                                                                                                          | 94                                                                       | 96                                                                                          | 98                                                                        |  |  |  |  |
| BPAR0*,<br>BPAR1*,<br>BPAR2*,<br>BPAR3*<br>ADDIR        | 62, 61, 59, 60<br>52      | The byte parity<br>a 74F245 or eq<br>operations and<br>generation and<br>port memory da<br>specification.<br>The AD direction                                                                     | signals are<br>uivalent tran<br>to drive byt<br>checking e<br>ata, address<br>on signal is a                                                                                                                                                                                                                                                                                                                                                 | bidirectiona<br>nsceiver. The<br>parity for coven if the ad<br>for reference<br>an output us | I lines that on<br>nese signals<br>butgoing ope<br>Idress/data<br>ce, etc.). Fu<br>ed to contro | connect to the<br>s are used to<br>erations. The<br>signals are our<br>of the direction<br>of the direction | e iPSB bus<br>receive byt<br>e MPC is re<br>driven from a<br>are availab | PAR* signa<br>e parity for i<br>sponsible fo<br>another sou<br>le in the iPS<br>245 or equi | ls through<br>ncoming<br>or parity<br>rce (e.g., dual-<br>B bus<br>valent |  |  |  |  |
|                                                         |                           | drives data to the                                                                                                                                                                                | ne iPSB bus                                                                                                                                                                                                                                                                                                                                                                                                                                  | thru BAD3                                                                                    | 1" and BPA                                                                                      | HO" thru BP                                                                                                 | AR3° signal                                                              | s. Activatin                                                                                | g this signal                                                             |  |  |  |  |
| REFADR*                                                 | 51                        | The reference a memory and I/0 BAD* bus.                                                                                                                                                          | address sigi<br>D reference                                                                                                                                                                                                                                                                                                                                                                                                                  | nal is an out<br>operations.                                                                 | put from the<br>Activating t                                                                    | MPC used<br>this signal d                                                                                   | to enable ex<br>rives the refe                                           | kternal addr<br>erence addr                                                                 | ess buffers for<br>ess onto the                                           |  |  |  |  |
| SCDIR0,<br>SCDIR1                                       | 32, 40                    | The control/har<br>equivalent trans<br>BSC9*. The So<br>iPSB bus.                                                                                                                                 | ndshake dire<br>sceivers for<br>CDIR1 signa                                                                                                                                                                                                                                                                                                                                                                                                  | ection signa<br>the BSC* si<br>al is used foi                                                | ls are outpu<br>gnals. The<br>r BSC4* - B                                                       | ts used to co<br>SCDIR0 sig<br>SC8*. Activ                                                                  | ontrol the dir<br>nal is used f<br>ating these                           | ection of the<br>or BSC0* -<br>signals drive                                                | e 74F245 or<br>BSC3* and<br>es data to the                                |  |  |  |  |
| BSC0*-<br>BSC9*<br>iPSB                                 | See Table                 | The control/har<br>74F245 or equi<br>bus specificatio                                                                                                                                             | ndshake sig<br>valent trans<br>on.                                                                                                                                                                                                                                                                                                                                                                                                           | nals are bid<br>cievers. De                                                                  | irectional lin<br>Itails on the                                                                 | es that conr<br>operation of                                                                                | ect to iPSB<br>these signa                                               | bus SC* sig<br>als are availa                                                               | nals through<br>able in the                                               |  |  |  |  |
|                                                         |                           |                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                              |                                                                                                 |                                                                                                             |                                                                          | BSC9*                                                                                       | BSC8*                                                                     |  |  |  |  |
|                                                         |                           |                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                              |                                                                                                 |                                                                                                             |                                                                          | 29                                                                                          | 37                                                                        |  |  |  |  |
|                                                         |                           | BSC7*                                                                                                                                                                                             | BSC6*                                                                                                                                                                                                                                                                                                                                                                                                                                        | BSC5*                                                                                        | BSC4*                                                                                           | BSC3*                                                                                                       | BSC2*                                                                    | BSC1*                                                                                       | BSC0*                                                                     |  |  |  |  |



| Signal<br>Name | Pin<br>Number | Signal<br>Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BBCLK          | 55            | The bus clock input signal is a buffered version of the iPSB bus BCLK* signal. It is assumed that a 74AS1804A or equivalent buffer is used. This clock is used for all synchronous internal MPC timing.                                                                                                                                                                                                                                                                                                                |
| TIMOUT         | 53            | The time out input signal is used to detect a time out condition signalled by the CSM. This signal is connected to the iPSB bus through a 74AS1804A or equivalent buffer.                                                                                                                                                                                                                                                                                                                                              |
| LACHN          | 54            | The latch signal is an input used during initialization of slot and arbitration IDs. When the RESET<br>signal is active, this signal indicates when slot and arbitration IDs are available. This signal is<br>connected to the iPSB bus through a 74AS1804A or equivalent buffer. Further details on<br>initialization are available in the iPSB bus specification.                                                                                                                                                    |
| RESET          | 58            | The reset signal is an input used to put the MPC in a known state. Only the parts of the MPC<br>involved with initialization of slot and arbitration IDs remain unaffected. This signal is buffered from<br>the iPSB bus by a 74AS1804A or equivalent buffer connected to the RST* signal.                                                                                                                                                                                                                             |
| BUSERR*        | 50            | The bus error signal is a bidirectional, open-drain line with high current drive. It connects directly<br>to the iPSB bus. As an input, it is used to detect bus errors signalled by other agents. As an output<br>it is used to signal parity errors detected on either the AD* or SC* signal lines, handshake protocol<br>violations, or for extending exception recovery of a replier.                                                                                                                              |
| RSTNC*         | 49            | The reset not complete signal is a bidirectional, open-drain line with high current drive. It connects directly to the iPSB bus. As an input, this signal inhibits the MPC from initiating iPSB bus operations. As an output it is used to prevent iPSB bus operation until an agent is finished with onboard initialization. This signal is activated by the RESET signal going active. It is deactivated by the interconnected microcontroller after the RESET signal is deactivated and initialization is complete. |
| SEL*           | 26            | The SEL* signal is activated by the MPC to indicate a dual-port access. This signal is used to<br>initiate the dual-port operation and may be used to enable the dual-port data buffers onto the BAD*<br>bus. When the MPC completes the iPSB bus handshake on the iPSB bus, or an exception is<br>detected, this signal deactivates.                                                                                                                                                                                  |
| COM*           | 31            | The COM* signal is activated by the dual-port memory controller to indicate it is ready to complete<br>the operation. This signal is assumed to be synchronous to the bus clock. The MPC activates<br>replier ready on the iPSB bus on the next bus clock. This signal may not be deactivated until the<br>EOT handshake is complete on the iPSB bus.                                                                                                                                                                  |
| ERR*           | 24            | The ERR* signal is activated by the dual-port memory controller to signal a memory data parity error.<br>It must be stable at all times when the COM* signal is active. The MPC responds to this signal by<br>completing the replier handshake on the iPSB bus using a "data error" agent error code. This signal<br>may be asynchronous to the bus clock since it is qualified by the COM* signal.                                                                                                                    |
| D0 - D31       | See Table     | The data bus is a bidirectional group of signals used to transfer data between the host CPU and the MPC. Control is provided to allow operation of this bus with 8-, 16-, or 32-bit processors.                                                                                                                                                                                                                                                                                                                        |

### SIGNAL DESCRIPTIONS (Cont.)



PRELIMINARY VL82C389

#### SIGNAL DESCRIPTIONS (Cont.) Signal Pin Signal Name Number Description A2, 2.5.3.4 The address inputs are used to identify MPC registers for message and interconnect space A3, operations. Note that A0 and A1 are omitted to provide a consistent register address for all data bus A4, width options. These signals are gualified by commands (e.g. RD\* or WR\*) in the MPC and therefore A5 may glitch outside the specified set-up and hold window. BE0\*. 6.8.9.7 The byte enable input signals are used to identify the valid bytes and for data path control during BE1\* memory and I/O reference operations. Only combinations supported by the iPSB bus specification BE2\* are valid. These are summarized in the table below. Values not shown are illegal and may result in BE3\* unpredictable results. These signals are qualified by commands (e.g. RD\* or WR\*) in the MPC and therefore may glitch outside the specified set-up and hold window. Operation with 32-bit local buses requires all byte enable and data signals to be used. For 16-bit local buses, the BE3\* and BE2\* signals are held inactive and only D15-D0 are used. For all cases a read operation enables all 32 data signals, even if all byte enables are inactive. For 8-bit local bus

operations BE3\* is held active, BE2\* is held inactive, BE1\* is connected to A0\*, and BE0\* is

|      |      |      |      |              | LOCA         | L BUS       |            |               | iPSB          | BUS          |             |
|------|------|------|------|--------------|--------------|-------------|------------|---------------|---------------|--------------|-------------|
| BE3* | BE2* | BE1* | BE0* | D31 -<br>D24 | D23 -<br>D16 | D15 -<br>D8 | D7 -<br>D0 | AD31-<br>AD24 | AD23-<br>AD16 | AD15-<br>AD8 | AD7-<br>AD0 |
| L    | L    | L    | L    | V3           | V2           | V1          | V0         | V3            | V2            | V1           | V0          |
| L    | L    | L    | н    | V3           | V2           | V1          | Х          | V3            | V2            | V1           | Х           |
| Н    | L    | L    | L    | X            | V2           | V1          | V0         | Х             | V2            | V1           | V0          |
| L    | L    | Н    | Н    | V3           | V2           | Х           | Х          | Х             | х             | V3           | V2          |
| Н    | L    | L    | н    | Х            | V2           | V1          | Х          | Х             | V2            | V1           | Х           |
| Н    | Н    | L    | L    | Х            | Х            | V1          | V0         | Х             | Х             | V1           | V0          |
| L    | Н    | Н    | Н    | V3           | Х            | Х           | Х          | X             | Х             | V3           | х           |
| Н    | L    | Н    | н    | х            | V2           | Х           | Х          | х             | Х             | Х            | V2          |
| H    | Н    | Ľ    | Н    | Х            | Х            | V1          | Х          | X             | Х             | V1           | X           |
| Н    | Н    | н    | L    | Х            | Х            | Х           | V0         | Х             | Х             | Х            | V0          |
| L    | Н    | L    | н    | Х            | X            | X           | V0         | X             | Х             | VO           | Х           |
| L    | Н    | L    | н    | Х            | Х            | Х           | V0         | X             | Х             | Х            | <b>V</b> 0  |

L - Electrical LOW State (Active)

H - Electrical HIGH State (Inactive)

connected to A0. This mode uses only D7-D0.

Vx - Valid Data Bytes

X - Active Bytes With Undefined Data

For References Only

MEMSEL\* 11

10

IOSEL\*

The memory select input signal is used to idenfity a memory reference operation to the iPSB bus. It is qualified by commands (e.g., RD\* or WR\*) in the MPC and therefore may glitch outside the specified set-up and hold window.

The I/O select input signal is used to identify an I/O reference operation to iPSB bus. It is qualified by commands (e.g., RD\* or WR\*) in the MPC and therefore may glitch outside the specified set-up and hold window.

REGSEL\* 12 The register select input signal is used to identify operations to internal MPC registers used to perform message and interconnect space operations. This signal is qualified by commands (e.g., RD\* or WR\*) in the MPC and therefore may glitch outside the specified set-up and hold window.

LOCK\* 23 The lock signal is an input to the MPC that allows back-to-back operations to be performed on the iPSB bus or to local interconnect space. When lock is asserted, any resource accessed by the operation (iPSB bus or local interconnect space) is locked until the LOCK\* signal is deactivated.



| Signal<br>Name | Pin<br>Number | Signal<br>Description                                         |                                                                                                                                           |                                                               |                                               |                                                   |                                              |                                                |                                                            |  |  |
|----------------|---------------|---------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|-----------------------------------------------|---------------------------------------------------|----------------------------------------------|------------------------------------------------|------------------------------------------------------------|--|--|
| RD*            | 18            | The read inp transitions.                                     | ut signal is                                                                                                                              | activated to                                                  | initiate a re                                 | ad operatio                                       | n. This signa                                | al must provi                                  | de clean                                                   |  |  |
| WR*            | 17            | The write inp<br>transitions.                                 | out signal is                                                                                                                             | activated to                                                  | initiate a w                                  | rite operatio                                     | n. This sigr                                 | al must prov                                   | vide clean                                                 |  |  |
| WAIT*          | 19            | The wait sign<br>MPC for all a<br>by a comma<br>requested o   | nal is driver<br>accesses th<br>nd going ac<br>peration.                                                                                  | n by the MP(<br>nat require sy<br>ctive and de                | C to hold up<br>ynchronizati<br>activated wł  | a transfer o<br>ion to anoth<br>nen the acce      | peration. T<br>er resource<br>essed resou    | his signal wi<br>When use<br>rce is ready      | ll be used by the<br>d, it is activated<br>to complete the |  |  |
| MINT           | 21            | The messag<br>includes arri<br>transfer, etc                  | e interrupt<br>val of an ur                                                                                                               | output signa<br>isolicited me                                 | al is used for<br>essage, con                 | all messag                                        | e-related sig<br>solicited tra               | gnalling to th<br>nsfer, error                 | e host CPU. This<br>on message                             |  |  |
| EINT           | 22            | The error int<br>space opera<br>space. (Eve<br>for simplicity | errupt outp<br>tions. Inter<br>on though the<br>in future se                                                                              | ut signal is u<br>mal register<br>nis is a local<br>ections.) | used to sign<br>s in the MP0<br>bus signal i  | al all errors i<br>C provide ex<br>t will be disc | elated to m<br>act details o<br>ussed with t | emory, I/O c<br>of the error v<br>he interconr | r interconnect<br>ia interconnect<br>nect bus signals      |  |  |
| ODREQ          | 16            | The output o<br>the MPC (e.                                   | channel DN<br>g., output to                                                                                                               | IA request s<br>the iPSB b                                    | ignal is gen<br>us).                          | erated by th                                      | e MPC to e                                   | nable DMA i                                    | transfer of data to                                        |  |  |
| IDREQ          | 15            | The input ch<br>the MPC (e.                                   | The input channel DMA request signal is generated by the MPC to enable DMA transfer of data from the MPC (e.g., input from the iPSB bus). |                                                               |                                               |                                                   |                                              |                                                |                                                            |  |  |
| ODACK*         | 14            | The output of MPC. It is q                                    | channel DN<br>ualified by o<br>t up and ho                                                                                                | IA acknowle<br>commands<br>Id window                          | dge input si<br>(e.g., RD* o                  | gnal is activ<br>r WR*) in th                     | ated to perf<br>e MPC and                    | orm a DMA<br>therefore m                       | data transfer to th<br>ay glitch outside                   |  |  |
| IDACK*         | 13            | The input ch<br>the MPC. It i<br>the specified                | annel DMA<br>is qualified<br>d set-up and                                                                                                 | acknowled<br>by comman<br>d hold windo                        | ge input sig<br>ds (e.g., RD<br>ow.           | nal is activa<br>* or WR*) in                     | ted to perfo<br>the MPC a                    | rm a DMA da<br>nd therefore                    | ata transfer from<br>may glitch outsid                     |  |  |
| IAD0-IAD7      | See Table     | The intercor<br>microcontro                                   | nnect addre<br>ller. In add                                                                                                               | ess/data bus<br>ition to the N                                | is a multiple<br>IPC, other i                 | exed bus de<br>nterconnect                        | signed to di<br>registers ca                 | rectly interfa<br>an be conne                  | ice to a<br>cted to this bus.                              |  |  |
|                |               | IAD7                                                          | IAD6                                                                                                                                      | IAD5                                                          | IAD4                                          | IAD3                                              | IAD2                                         | IAD1                                           | IAD0                                                       |  |  |
|                |               |                                                               | 107                                                                                                                                       | 110                                                           | 106                                           | 109                                               | 104                                          | 108                                            | 105                                                        |  |  |
| IREQ*          | 100           | The intercor<br>requested e<br>microcontro                    | nnect reque<br>ither from ti<br>ller perform                                                                                              | est signal is g<br>he local bus<br>is arbitration             | generated b<br>or from the                    | y the MPC v<br>iPSB bus. ∃                        | vhen an inte<br>This signal r                | erconnect op<br>emains activ                   | eration has been<br>ve until the                           |  |  |
| IAST           | 101           | The intercor<br>is on the inte<br>microcontro                 | nnect addre<br>erconnect b<br>llers. This                                                                                                 | ess strobe si<br>ous.This sigr<br>signal must                 | gnal is an in<br>1al may be d<br>provide clea | put to the M<br>lirectly conn<br>in transition    | PC used to<br>ected to the<br>s.             | indicate that<br>ALE output                    | t a valid address<br>of most                               |  |  |
| IRD*           | 102           | The intercor<br>operation to<br>transitions.<br>disabled.     | nnect bus re<br>one of the<br>When this                                                                                                   | ead signal is<br>MPC interco<br>signal is acti                | an input to<br>onnect inter<br>vated in cor   | the MPC. T<br>ace register<br>njunction wit       | his signal is<br>s. This sigr<br>h the IWR*  | used to per<br>nal must pro<br>signal, all M   | form a read<br>vide clean<br>PC outputs are                |  |  |
| IWR*           | 103           | The intercor<br>operation to<br>transitions.<br>disabled.     | nnect bus w<br>one of the<br>When this                                                                                                    | vrite signal is<br>MPC interco<br>signal is acti              | an input to<br>onnect inter<br>vated in cor   | the MPC. 1<br>ace register<br>njunction wit       | his signal is<br>s. This sign<br>h the IRD*  | s used to per<br>nal must pro<br>signal, all M | form a write<br>vide clean<br>PC outputs are               |  |  |

# SIGNAL DESCRIPTIONS (Cont.)

# **ABSOLUTE MAXIMUM RATINGS**

| Ambient Operating<br>Temperature      | - 10°C to +80°C      |
|---------------------------------------|----------------------|
| Storage Temperatur                    | re - 65°C to +150°C  |
| Supply Voltage to<br>Ground Potential | - 0.5 V to +7.0 V    |
| Applied Output<br>Voltage             | - 0.3V to VCC +0.5 V |
| Applied Input<br>Voltage              | - 0.5V to VCC +0.5 V |

Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only. Functional operation of this device at these or other conditions above those indicated in the operational sections of this specification is not implied and exposure to absolute maximum rating conditions for extended periods may affect device reliablity.

## **DC CHARACTERISTICS** TA = $0^{\circ}$ C to + 70°C, VCC = 5 V± 5%

| Symbol | Parameter               |                                       | Min   | Мах     | Units | Test Conditions |
|--------|-------------------------|---------------------------------------|-------|---------|-------|-----------------|
| VIL    | Input LOW Voltage       |                                       | - 0.5 | 0.8     | V     |                 |
| VIH    | Input HIGH Voltage      | · · · · · · · · · · · · · · · · · · · | 2.0   | VCC+0.5 | V     |                 |
| VOL    | Output LOW              | Open Drain                            |       | 0.55    | V     | IOL Max         |
|        | Voltage                 | All Others                            |       | 0.45    | V     | IOL Max         |
| VOH    | Output HIGH Voltage     |                                       | 2.4   |         | V     | IOH Max         |
|        |                         | Open Drain                            | -     | ± 400   | μA    | 0 ≤ VIN ≤ VCC   |
| ILI    | Current                 | BBCLK                                 | -     | ± 100   | μΑ    | 0 ≤ VIN ≤ VCC   |
|        |                         | All Others                            | -     | ± 10    | μA    | 0 ≤ VIN ≤ VCC   |
|        | -                       | Open Drain                            | 60.0  | -       | mA    | VOL = 0.55 V    |
| IOL    | Output LOW<br>Current   | ADDIR and<br>REFADR*                  | 8.0   | -       | mA    | VOL = 0.45 V    |
|        |                         | All Others                            | 4.0   | -       | mA    | VOL == 0.45 V   |
| IOH    | Output HIGH Current     |                                       | - 1.0 | -       |       | VOH = 2.4 V     |
| ICC    | Operating Supply Curren | t                                     | -     | 400     | mA    |                 |

# CAPACITANCE TA = + 25°C, FC = 1 MHz (Note 1)

| Symbol | Parameter          | Min        | Max | Units | Test Conditions |  |
|--------|--------------------|------------|-----|-------|-----------------|--|
|        |                    | BBCLK      | -   | 15    | pF              |  |
| CI     | Input Capacitance  | All Others | -   | 10    | pF              |  |
| CIO    | I/O Capacitance    |            | -   | 20    | pF              |  |
| COC    | Output Capacitance | -          | 20  | pF    |                 |  |

Notes:

1. Periodically sampled as opposed to 100% tested.

# VL82C389 PRELIMINARY

# AC CHARACTERISTICS TA = 0°C to +70°C, VCC = 5 V $\pm$ 5%

| Symbol | Parameter                                        |                      | Min                                       | Max | Units | Test Conditions |
|--------|--------------------------------------------------|----------------------|-------------------------------------------|-----|-------|-----------------|
|        | Address and BE* Set-Up                           | To Command Active    | 30                                        | -   | ns    |                 |
| n      | Select and DACK Set-Up                           | To Command Active    | 24                                        | -   | ns    |                 |
| T2     | Address, BEn*, Select*, a<br>From Command Active | nd DACK* Hold        | 10                                        | -   | ns    |                 |
| Т3     | Command Inactive                                 |                      | 35                                        | _   | ns    |                 |
| Τ4     | Command Inactive To Re<br>(Note 6)               | ad Data Disable      |                                           | 24  | ns    |                 |
| Т5     | Read Data Hold From Co                           | 3                    | -                                         | ns  |       |                 |
| Т6     | Read Data Enable From (                          | Command Active       | 0                                         |     | ns    |                 |
| T7     | WAIT* Active From Comr                           | nand Active          |                                           | 35  | ns    | CL = 50 pF      |
| Т8     | Command Inactive From                            | WAIT* Inactive       | 0                                         | -   | ns    |                 |
| Т9     | WAIT* Inactive To Read I                         | Data Valid           |                                           | 50  | ns    | CL = 150 pF     |
| T10    | Command Active To Write                          | ə Data Valid         | -                                         | 200 | ns    |                 |
| T11    | Write Data Hold From WA                          | NT* Inactive         | 0                                         | -   | ns    |                 |
| T12    | Command Active To LOC                            | K* Active (Note 2)   |                                           | 100 | ns    |                 |
| T13    | LOCK* Hold From WAIT                             | * Inactive (Note 3)  | 0 × 1                                     | -   | ns    |                 |
| T14    | Command Active                                   |                      | 70                                        | -   | ns    |                 |
| T15    | Read Data Valid From Co                          | mmand Active         | <u> </u>                                  | 60  | ns    | CL = 150 pF     |
| T16    | Write Data Set-Up To                             | Registers            | 35                                        | -   | ns    |                 |
|        | Command Inactive                                 | DMA                  | 25                                        | -   | ns    |                 |
| T17    | Write Data Hold From Co                          | mmand Inactive       | 5                                         | -   | ns    |                 |
| T18    | Command Active To MIN<br>(Note 4,5)              | T Or DREQ Inactive   |                                           | 70  | ns    | CL = 50 pF      |
| T19    | Command Active To DRE                            | Q* Inactive (Note 5) | in an | 45  | ns    | CL = 50 pF      |

# AC TEST CONDITIONS



OUTPUT WAVEFORM TEST POINTS



### Notes:

- 2. Required to guarantee locking of resource.
- 3. Required to guarantee resource remains locked.

4. MINT deassertion only if no other sources are pending.

5. For DREQ inactive timing, T19 applies to a normal last transfer deassert condition and T18 to an error deassert condition.

# AC TEST LOAD CIRCUIT





G

# TIMING DIAGRAMS

### FIGURE 1 LOCAL BUS REFERENCE



FIGURE 2. LOCAL BUS REGISTER AND DMA OPERATIONS



# VL82C389 PRELIMINARY

# AC CHARACTERISTICS TA = 0°C to +70°C, VCC = 5 V ±5%

| Symbol | Parameter                                             | Min | Max | Units | Test Conditions                                                                                                 |
|--------|-------------------------------------------------------|-----|-----|-------|-----------------------------------------------------------------------------------------------------------------|
| T31    | IAST Active                                           | 85  | _   | ns    |                                                                                                                 |
| T32    | Command Active                                        | 250 | -   | ns    |                                                                                                                 |
| T33    | Command Inactive To IAST Active                       | 25  | -   | ns    |                                                                                                                 |
| T33A   | IAST Inactive To Command Active                       | 120 | -   | ns    |                                                                                                                 |
| T34    | Address Set-Up To IAST Inactive                       | 40  | ÷   | ns    | tak san ta                                                                                                      |
| T35    | Address Hold From IAST Inactive                       | 20  | -   | ns    |                                                                                                                 |
| T36    | Write Data Set-Up To Command Inactive                 | 120 | -   | ns    |                                                                                                                 |
| T37    | Write Data Hold From Command Inactive                 | 5   | · _ | ns    |                                                                                                                 |
| T38    | Read Data Enable From Command Active                  | 0   | -   | ns    |                                                                                                                 |
| T39    | Read Data Valid From Command Active                   | -   | 120 | ns    | CL = 150 pF                                                                                                     |
| T40    | Read Data Hold From Command Inactive                  | 0   | -   | ns    |                                                                                                                 |
| T41    | Read Data Disable From Command Inactive ( Note 8)     | -   | 30  | ns    | age of the second se |
| T42    | EINT, IREQ* Inactive From CommandActive<br>( Note 7 ) | _   | 100 | ns    | CL = 50 pF                                                                                                      |

## **TIMING DIAGRAM**

FIGURE 3. INTERCONNECT BUS



### Notes:

7. EINT inactive only on write to error register. IREQ\* inactive only on write to arbitration register.

8. Disable condition occurs when the output current becomes less than the input leakage specification.

PRELIMINARY VL82C389

| Symbol | Parameter                |                                  |                     | Min  | Max  | Units | Test Conditions |
|--------|--------------------------|----------------------------------|---------------------|------|------|-------|-----------------|
| ТСР    | Clock Period             | eriod                            |                     |      | -    | ns    |                 |
| TCL    | BCLK* LOW Tir            | ne                               |                     | 40   | -    | ns    |                 |
| тсн    | BCLK* HIGH Ti            | me                               |                     | 40   | _    | ns    |                 |
| TBCL   | BBCLK LOW T              | ime                              |                     | 38   | -    | ns    |                 |
| ТВСН   | BBCLK HIGH T             | ĩme                              |                     | 38   | _    | ns    |                 |
| TRB    | BCLK* Rise Tin           | ne                               |                     | 1.0  | 5.0  | ns    |                 |
| TFB    | BCLK* Fall Tim           | e                                |                     | 1.0  | 2.0  | ns    |                 |
| TR     | BBCLK Rise Ti            | me                               |                     | 0.5  | 1.0  | ns    |                 |
| TF     | BBCLK Fall Tim           | าย                               |                     | 0.5  | 1.0  | ns    |                 |
| TSK    | BCLK* To BBC             | LK Skew ( No                     | te 9)               | -0.5 | 4.0  | ns    |                 |
|        |                          | BREQ*, BU<br>RSTNC* (            | JSERR*,<br>Note 10) | -    | 36   | ns    | CL = 500 pF     |
|        | Clock To<br>Output Delay | ARB5* - Al                       | RB0* (Note 10,11)   | -    | 36   | ns    | CL = 500 pF     |
|        |                          | BSC7* - BSC0*,<br>BAD31* - BAD0* |                     | -    | . 29 | ns    | CL = 75 pF      |
| TCD    |                          | BPAR3* - I<br>BSC9*, BS          | BPAR0*,<br>6C8*     |      | 29   | ns    | CL = 50 pF      |
| 100    |                          | SCDIR0,                          | HIGH To LOW         | -    | 19   | ns    | CL = 25 pF      |
|        | -                        | SCDIR1                           | LOW To HIGH         | -    | 21   | ns    | CL = 25 pF      |
|        |                          |                                  | HIGH To LOW         | - "  | 27   | ns    | CL = 50 pF      |
|        |                          | ADDIN                            | LOW To HIGH         |      | 21   | ns    | CL = 50 pF      |
|        |                          | REFADR*                          |                     | -    | 29   | ns    | CL = 75 pF      |
|        |                          | SEL*                             |                     | -    | 29   | ns    | CL = 50 pF      |
|        |                          | BREQ*, BU                        | JSERR*, RSTNC*      | 6.5  | _    | ns    |                 |
|        |                          | ARB5* - Al                       | RB0*(Note 11)       | 6.5  | -    | ns    |                 |
|        |                          | BAD31* - E<br>BPAR3* - I         | BAD0*,<br>BPAR0*    | 5.0  | -    | ns    |                 |
| тн     | Hold Time<br>From Clock  | BSC9* - B                        | SC0*                | 4.0  | -    | ns    |                 |
|        |                          | SCDIR0, S                        | CDIR1               | 4.0  | -    | ns    |                 |
|        |                          | ADDIR                            |                     | 5.0  |      | ns    |                 |
|        |                          | REFADR*                          |                     | 4.0  | _    | ns    |                 |
|        |                          | SEL*                             |                     | 4.0  | _    | ns    |                 |

# AC CHARACTERISTICS TA = 0°C to +70°C, VCC = 5 V ±5%

#### Notes:

9. The clock timings are provided to reference the MPC specification to the iPSB bus specifications. These specifications assume a 74AS1804 or equivalent buffer.

10. The 500 pF load is a distributed value as defined in the iPSB bus specification. The open drain signals are designed such that the output delay and bus loss meets the iPSB specification requirement. An appropriate test condition that correlates to the distributed load will be determined during characterization.

11. The ARB5\* ARB0\* signal timings are with respect to the first and last clock of the arbitration period. Details can be found in the iPSB bus specification. Also, the arbitration logic has been designed to meet the loop delay specification accounting for the full path of input to output plus bus loss. An appropriate test condition will be determined during device characterization.

# VL82C389 PRELIMINARY

| Symbol                                   | Parameter                                                                                                      | en en la grectione en la construction de la construction de la construction de la construction de la construction<br>La construction de la construction d | Min    | Мах              | Units | Test Conditions |
|------------------------------------------|----------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------|-------|-----------------|
|                                          |                                                                                                                | BREQ*, BUSERR*, RSTNC*                                                                                                                                                                                                                | 6.5    | · · · · · ·      | ns    |                 |
| TON                                      | Turn On Delay<br>From Clock<br>( Note 12 )                                                                     | ARB5* - ARB0* (Note 9)                                                                                                                                                                                                                | 6.5    | -                | ns    |                 |
| TON                                      |                                                                                                                | BAD31* - BAD0*,<br>BPAR3* - BPAR0*                                                                                                                                                                                                    | 5.0    |                  | ns    |                 |
|                                          |                                                                                                                | BSC9* - BSC0*                                                                                                                                                                                                                         | 4.0    |                  | ns    |                 |
| 10 A.                                    |                                                                                                                | BREQ*, BUSERR*, RSTNC*                                                                                                                                                                                                                |        | 36               | ns    |                 |
| TOFF                                     | Turn Off Delay                                                                                                 | ARB5* - ARB0* (Note 11)                                                                                                                                                                                                               | ng 🚽 👘 | 36               | ns    |                 |
| IOFF                                     | From Clock<br>(Note 13)                                                                                        | BAD31* - BAD0*,<br>BPAR3* - BPAR0*                                                                                                                                                                                                    | -      | 29               | ns    |                 |
|                                          |                                                                                                                | BSC9* - BSC0*                                                                                                                                                                                                                         | -      | 29               | ns    |                 |
| ÷.,                                      |                                                                                                                | BREQ*, BUSERR*, RSTNC*                                                                                                                                                                                                                | 22     | -                | ns    |                 |
|                                          | and and a second se | ARB5* - ARB0* (Note 11)                                                                                                                                                                                                               | 40     | _                | ns    |                 |
| TSU                                      | Input Set-Up<br>To Clock                                                                                       | BAD31* - BAD0*,<br>BPAR3* - BPAR0*                                                                                                                                                                                                    | 24     | -                | ns    |                 |
|                                          |                                                                                                                | BSC9* - BSC0*                                                                                                                                                                                                                         | 24     |                  | ns    |                 |
|                                          |                                                                                                                | TIMOUT, LACHN, RESET                                                                                                                                                                                                                  | 24     |                  | ns    |                 |
|                                          |                                                                                                                | COM*, ERR*                                                                                                                                                                                                                            | 40     | -                | ns    |                 |
|                                          |                                                                                                                | BREQ*, BUSERR*, RSTNC*                                                                                                                                                                                                                | 0      | -                | ns    |                 |
|                                          |                                                                                                                | ARB5* - ARB0* (Note 11)                                                                                                                                                                                                               | 0      | an <u>a</u> nta, | ns    |                 |
| ТІН                                      | Input Hold<br>From Clock                                                                                       | BAD31* - BAD0*,<br>BPAR3* - BPAR0*                                                                                                                                                                                                    | 3      | -                | ns    |                 |
| an a |                                                                                                                | BSC9* - BSC0*                                                                                                                                                                                                                         | 2      |                  | ns    |                 |
|                                          |                                                                                                                | TIMOUT, LACHN, RESET                                                                                                                                                                                                                  | 2      | ,                | ns    |                 |
|                                          |                                                                                                                | COM*, ERR*                                                                                                                                                                                                                            | 3      | _                | ns    |                 |

### AC CHARACTERISTICS TA = 0°C to +70°C, VCC = 5 V ±5%

### **TIMING DIAGRAM**



### Notes:

12. Minimum turn-on times are measured the same way as hold times. Specifically, the logic level driven by another device on the previous clock cycle must not be disturbed.

13. Maximum turn-off times are measured to the condition where the output leakage current becomes less than the input leakage specification.



| <br> | SECTION 4<br>PERIPHER | 4<br>IALS |
|------|-----------------------|-----------|
|      |                       |           |
| <br> |                       |           |
|      |                       |           |
|      |                       |           |
|      |                       |           |
|      |                       |           |
|      |                       |           |
|      |                       |           |

Application Specific Logic Products Division



# VL16160



# "RASTER OP" GRAPHICS/BOOLEAN OPERATION ALU

# FEATURES

- Provides hardware assist for bitmapped graphics operations. Includes 32-bit barrel shifter.
- Performance increase over software implementations:
  - Monochrome = 4 X Software
  - Color = 4 X (Planes) X Software
- Supports both CRT displays and such hardcopy devices as laser printers.
- Compatible with both monochrome and color displays.
- Implements all 256 possible raster operations on source, destination, and pattern data.
- 28- pin package; 5 V supply.

# **PIN DIAGRAM**

#### mapped graphics displays. These operations, commonly called Bit Block Translation (BITBLT), allow bit-mapped images to be combined and manipulated by logical operators. These operators isolude AND, OR, and XOR, and each be

DESCRIPTION

provides hardware-assisted

include AND, OR, and XOR, and can be used on source, destination, and pattern data. Additionally, support for masking with multiple mask registers for clipping is included.

The VL16160 Raster Op ALU (RALU)

performance enhancements for bit

manipulation operations used in bit-

The BITBLT operation is general purpose enough to be used in a wide range of graphics operations, including text display using arbitrary fonts, attributes, and enhancements. Successive applications of BITBLTs can perform such operations as scaling, filling, rotations, and texturing.

In a typical application, the RALU operates on display data in 16-bit words that are latched into its input buffers by externai hardware. Once source, destination, pattern, shift, and masking data are loaded into the RALU, the source data is bit-aligned with the destination data and the logical operation specified in the function register takes place. The results are stored in the ALU Output Register, which can be output onto the bus by a single strobe signal.



### **ORDER INFORMATION**

| Part<br>Number | Package                            |
|----------------|------------------------------------|
| VL16160PC      | Plastic DIP                        |
| VL16160CC      | Ceramic DIP                        |
| VL16160QC      | Plastic Leaded Chip Carrier (PLCC) |

### VL16160

| A0  | d | 1  | $\mathbf{O}$ | 28 | þ | vcc   |
|-----|---|----|--------------|----|---|-------|
| A1  | d | 2  |              | 27 | þ | RD    |
| A2  | р | 3  |              | 26 | þ | WR    |
| A3  | р | 4  |              | 25 | þ | LDstb |
| ĊS  | þ | 5  |              | 24 | þ | LSstb |
| D0  | q | 6  |              | 23 | þ | AOstb |
| D1  | q | 7  |              | 22 | þ | D15   |
| D2  | q | 8  |              | 21 | þ | D14   |
| D3  | q | 9  |              | 20 | þ | D13   |
| D4  | þ | 10 |              | 19 | þ | D12   |
| D5  | þ | 11 |              | 18 | þ | D11   |
| D6  | þ | 12 |              | 17 | þ | D10   |
| D7  | þ | 13 |              | 16 | þ | D9    |
| GND | q | 14 |              | 15 | þ | D8    |
|     |   |    |              |    |   |       |



# FIGURE 1. TYPICAL APPLICATION



# SIGNAL DESCRIPTIONS

| Signal<br>Name | Pin<br>Number | Signal<br>Description                                                                                                                                                                                                                                                                              |
|----------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D0-D15         | 6-15          | Bidirectional data lines; input enabled by $\overline{CS}$ and $\overline{WR}$ . Input data to Destination Register must be stable relative to the trailing edge of LDstb. Output enabled by $\overline{CS}$ , RD, and A0-A3 or AOstb.                                                             |
| CS             | 5             | Chip Select; Must be active to write to or read from internal registers.                                                                                                                                                                                                                           |
| RD             | 27            | Read Enable; Input used to strobe any internal register data to the data bus pins. Must be active in conjunction with $\overline{CS}$ .                                                                                                                                                            |
| WR             | 26            | Write Enable; Input used to strobe data on data bus pins into the selected register. Must be active in conjunction with CS.                                                                                                                                                                        |
| A0-A3          | 1-4           | Register Address; Address inputs that specify the internal chip register to be accessed for a read or write operation.                                                                                                                                                                             |
| AOstb          | 24            | ALU Output Strobe; Input used to enable the output of the function decoder onto the data bus pins. Cannot be active when CS and RD or WR are active.                                                                                                                                               |
| LDstb          | 25            | Load Destination Register Strobe; Input used to strobe the value (address) on the data<br>bus pins into the Destination Register. Value on A0-A3 need not be valid when LDstb is<br>used to load the Destination Register. The LDstb pin also decrements the op counter each<br>time it is pulsed. |
| LSstb          | 24            | Load Source Register Strobe; Input used to strobe the value on the data bus into the<br>Source Register specified by the Direction Bit. The other Source Register is loaded with<br>the previous contents of the Source Register being loaded.                                                     |
| GND            | 14            | Ground                                                                                                                                                                                                                                                                                             |
| VCC            | 28            | +5 V±5%                                                                                                                                                                                                                                                                                            |



# FUNCTIONAL DESCRIPTION

The VL16160 consists of four basic blocks: Source Shifter, Function Decoder, Op Counter, and the Register set. The internal data bus is 16 bits wide, enabling all internal registers to be accessed easily from the I/O bus for context saving and restoring. In operation, the Source Shifter extracts data from the Source Registers and shifts the data to be aligned with the data in the Destination and Pattern Registers. The Function Decoder then performs a 16-bit Boolean operation as specified by the Function Register with the data extracted from the Source Registers and the data in the Destination and Pattern Registers. The result of the Boolean operation is available on the external I/O bus when the AOstb signal is strobed and can easily be written back into display memory. The Op counter and associated registers provide the support for clipping operations as required by the application.

### SOURCE SHIFTER

The Source Shifter performs bit alignment on the concatenated 32 bits of data in the Source 1 and Source 2 Registers. The amount of bit alignment performed is based upon the value in the Shift Value Register. Thus, when LSstb is strobed, the Source Shifter extracts 16 contiguous bits from the 32 bits of data in the Source 1 and Source 2 registers as follows:

- If the low order four bits of the Shift Value Register have a non-zero value, that value specifies the shift count by which the 16-bit field to be extracted is offset from bit 0 of the concatenated source registers, as shown in figure 2. The result is passed on to the Function Decoder.
- 2. If the low-order four bits of the Shift Value Register is 0, the contents of either Source 1 or Source 2 are passed directly to the Function Decoder and no shifting occurs. The direction bit indicates which source register is used in the operation, as shown in figure 2.

### FUNCTION DECODER

The Function Decoder performs a

Boolean operation on the contents of the Destination Register, Pattern Register, and the output of Source Shifter. The Boolean operation is specified by the Function Register. With the three operands, 256 different Boolean operations are possible. The result of the operation is available on the I/O bus when the AOstb control signal is active. AOstb signal cannot be active at the same time that CS and RD or WR are active. The result of the Boolean operation is also available by reading the ALU Output Register.

To understand how the Function Decoder performs the desired Boolean operation, note again that with three operands, (data in the Source, Pattern and Destination Registers), a total of 256 different boolean operations is possible. Out of these 256 possible operations, the application defines which are needed to perform the desired task.

For example (see figure 3), to "paint" a new image over an existing image requires the source data (image) to be ORed with the destination data (image). This means "Source Register or Destination Register". For each bit, there are four possible results of this operation between these two registers. However, since the Pattern Register is always included, even when it is a "don't care," a total of eight different possible results of this one Boolean operation is possible. These eight combinations define the "function code" for the OR operation. Thus, the function code is really defined as the result (and the only result possible) of a Boolean combination of the Source. Destination. and Pattern Registers. In using the VL16160, the application defines which of the 256 possible Boolean combinations of the Source. Destination and Pattern Registers define those "functions" required of the application, and when that "function" is required, the corresponding function code is loaded into the Function Register.

In principal, the Function Decoder operates on a bit-by-bit basis as a 1-of-8 data selector with each data bit in the Source, Destination, and Pattern Registers selecting one of eight bits of data from the Function Register.

The function codes required of an application are determined ahead of time by the user and stored in memory to be used as needed. The determination of the correct function code is a matter of simply applying the definitions stated above (see figure 3), in a simple method. The truth table for Pattern, Source, and Destination bits is written, with the desired output. This desired output is read as the desired value of the Function Register, with the least significant bit as shown in figure 3. Using this method, the software engineer can easily define a pattern to suit each specific need.

### **OP COUNTER**

The Op Counter, in conjunction with the Width and Mask Registers, provides for masking of selected bits in the Destination Register. This masking prevents the VL 16160 from modifying selected areas of display memory when performing BITBLTs. For example, clipping may be required at the edges of a window. The function of the Op Counter is to keep track of the beginning and end of each row, so that the mask registers can handle this clipping automatically, without additional processor intervention.

The Op Counter must be correctly initialized prior to the beginning of a raster operation. The enabling of masking is internally clocked by the LDstb signal. For this reason, after loading the Op counter with an initial value, LDstb must be pulsed before the LSstb of the first operation. Since this LDstb will decrement the Op Counter, it is necessary to increment the Op Counter to be one more than the intended value, so that this "dummv" LDstb starts out the BITBLT with the correct Op Counter value. This "dummy" LDstb does have to be repeated between scanlines, as the masking remains enabled. If context switching is utilized, however, reinitialization (with the loading of Op Counter and subsequent LDstb) is necessary before leaving a context, or upon re-entering one, in the middle of a BITBLT.



# **REGISTER DESCRIPTION**

As shown in the block diagram, the RALU consists of a number of registers, each connected to the internal 16-bit data path. Of these registers, three are used very often and are directly accessible from the data bus by the assertion of strobe signals. MASK 1 and 2

used.

PATTERN

FUNCTION

**OP COUNTER** 

These registers are used to define the

left and right boundaries of the area on

the screen that is manipulated. (The

corresponds to left vs. right). A bit set

corresponding bit in the Destination

Register to pass through unaltered.

When the Op Counter is equal to the

raster operation on each scan line), the

Width Register (usually for the first

Mask 1 Register selects bits to be

This register contains data to be

shifted source register. This is

with a background pattern.

combined with the output of the bit-

This register contains the operator

that is used to combine the source,

The Op Counter Register specifies the

decremented each time LDstb is brought

active. After the Op counter goes to

zero, the next LDstb causes the Op

destination, and pattern data,

current count of the operation in

progress. The Op Counter is

commonly used for enhancing an image

included in the operation. Masking is

disabled until the Op Counter is zero

(usually for the last operation on a scan

line); at that time, the Mask 2 register is

direction bit affects which register

in these registers allows the

### SOURCE

The Source Register holds a 16-bit word of data to be modified by a raster operation. It is loaded from the data bus by the assertion of the LSstb signal.

### DESTINATION

The Destination Register holds a word of data from the bit-mapped display that is modified by the source data and raster operation. It is loaded from the data bus by the assertion of the LDstb signal.

### ALU OUTPUT

The ALU Output Register holds the result of the raster operation to be written back to memory. The contents may be put onto the data bus by the assertion of the AOstb signal.

The remainder of the registers are typically set up for a series of operations and are not changed until the end of a scan line.

#### **DIR / SHIFT**

This register controls the direction of the raster operation (left-to-right or right-toleft). In addition, it specifies the number of bits to shift to align the source with the destination fields.

# FIGURE 3. SHIFTING AND DIRECTION



counter to be reloaded with the value of the Width register prior to the next operation. The Op counter can be set to the value of the Width Register at the start of a raster operation by beginning an operation with a "dummy" LDstb. This loads the Op counter in preparation for the first scan line.

### WIDTH

The Width Register specifies the width of the line (in 16-bit words) on which raster operations will take place.

#### FLAG REGISTER

The Flag Register is uncommitted and can be used to temporarily store context information for multi-tasking implementations.

## REGISTER MAP





### FIGURE 3. RASTER OPERATIONS EXAMPLE











Source XOR Destination OR Pattern = F6 (hex)



Source HOR Destination = 66 (hex)











Source AND Destination = 88 (hex)








## **ABSOLUTE MAXIMUM RATINGS**

 Supply Voltage
 -0.5 V to +7.0 V

 Input Voltage
 -0.5 V to +7.0 V

 Output Voltage
 -0.5 V to +7.0 V

 Operating Temperature
 0 °C to +70 °C

 Storage Temperature
 0 °C to +150 °C

 Lead Temperature (10 s.)
 300 °C

 Junction Temperature
 175 °C

Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only. Functional operation of this device under these or any other conditions above those listed in this specification is not implied. Exposure to absolute maximum ratings conditions for extended periods may affect device reliability.

## DC CHARACTERISTICS TA = 0°C to +70°C, VCC = 5 V $\pm$ 0.25 V

| Symbol | Parameter                  |                  | Min | Тур | Max                                   | Unit                 | Conditions          |  |
|--------|----------------------------|------------------|-----|-----|---------------------------------------|----------------------|---------------------|--|
| VIH    | HIGH-Level Input Voltage   |                  | 2.4 |     |                                       | V                    |                     |  |
| VIL    | LOW-Level Input Voltage    |                  |     |     | 0.6                                   | v                    |                     |  |
| VOH    | HIGH-Level Output Voltage  | 2.4              |     |     | v                                     | VCC=Min; IOH=-400 μA |                     |  |
| VOL    | LOW-Level Output Voltage   |                  |     | 0.3 | 0.45                                  | v                    | VCC=Min; IOL=4.4 mA |  |
| IOH    | HIGH-Level Output Current  |                  |     |     |                                       | μA                   | -                   |  |
| IOL    | LOW-Level Output Current   |                  | 4.4 |     | , , , , , , , , , , , , , , , , , , , | mA                   |                     |  |
| IIL    | Input Leakage Current      |                  |     |     | 10                                    | μA                   | VI = 0.45 V         |  |
|        |                            | 0.7 V < Vo < Vcc |     |     | 20                                    |                      |                     |  |
| II/O   | I/O Leakage Current        | 0.4 V < Vo < Vcc |     |     | 100                                   | ] μΑ                 |                     |  |
| ICC    | Power Supply Current at DC |                  |     |     | 120                                   | mA                   | VCC = Max           |  |

## CAPACITANCE TA = 0°C to +70°C

| Symbol | Parameter         | Min | Тур | Max | Unit | Conditions |
|--------|-------------------|-----|-----|-----|------|------------|
| CI/O   | I/O Capacitance   |     |     | 15  | рF   |            |
| CI     | Input Capacitance |     | 6   | 15  | pF   |            |

4--8



## AC TIMING CHARACTERISTICS TA = 0°C to +70°C, VCC = 5 V $\pm$ 0.25 V

| Symbol | Parameter                               | Min | Max | Unit | Conditions |
|--------|-----------------------------------------|-----|-----|------|------------|
| tCSH   | CS, A0-A3 Hold After WR Active          | 20  |     | ns   |            |
| tRWW   | WR, RD Signal Width                     | 60  |     | ns   |            |
| tCSS   | CS, A0-A3 Setup to WR Inactive          | 0   |     | ns   |            |
| CSV    | Data Valid After CS Active              |     | 120 | ns   |            |
| tRDV   | Data Valid After RD Active              |     | 120 | ns   |            |
| tRDH   | Data Valid After RD, CS Inactive        | 5   |     | ns   |            |
| tWRS   | Data Setup to WR Inactive               | 50  |     | ns   |            |
| tWRH   | Data Hold After WR Inactive             | 30  |     | ns   |            |
| tLSW   | LSstb Pulse Width                       | 60  |     | ns   |            |
| tNLS   | Time Between LSstb Pulses               | 0   |     | ns   |            |
| tSDV   | LSstb Inactive to Valid Data            |     | 120 | ns   |            |
| LSF    | LSstb Inactive to AOstb Active          | 30  |     | ns   |            |
| tLDV   | LSstb Active to Valid Data              |     | 170 | ns   |            |
| tLDW   | LDstb Pulse Width                       | 60  |     | ns   |            |
| tNLD   | Time Between LDstb Pulses               | 150 |     | ns   |            |
| tLDF   | LDstb Inactive to AOstb Active          | 20  |     | ns   |            |
| tLSS   | Data Setup to LSstb Inactive            | 20  |     | ns   |            |
| tLSH   | Data Hold after LSstb Inactive          | 25  |     | ns   |            |
| tLDS   | Data Setup to LDstb Inactive            | 30  |     | ns   |            |
| tLDH   | Data Hold After LDstb Inactive          | 25  |     | ns   |            |
| tFOV   | Data Valid After AOstb Active           |     | 120 | ns   |            |
| tDDV   | Data Valid After Valid LDstb Data       |     | 140 | ns   |            |
| tFDV   | Bus High-Impedence After AOstb Inactive |     | 40  | ns   |            |



## FIGURE 4. REGISTER READ/WRITE TIMING







## VL1772-02



- Built-in data separator
- Built-in write precompensation
- · 5 1/4-inch single and double density
- Motor control
- 128, 256, 512, or 1024 sector lengths
- TTL compatible
- 8-bit bidirectional data bus
- Fast step rates
- 28-pin DIP
- Single 5 V power supply

### DESCRIPTION

The VL1772-02 is a MOS/LSI device that performs the functions of a 5 1/4inch Floppy Disk Controller/Formatter. It replaces the older 1770-type device.

VL1772-02

## **PIN DIAGRAM**

| $\overline{\text{CS}}$ |   |    | 28 |   | INTRQ |
|------------------------|---|----|----|---|-------|
| R∕₩                    |   | 2  | 27 |   | DRQ   |
| A0                     |   | 3  | 26 |   | DDEN  |
| A1                     |   | 4  | 25 |   | WPRT  |
| DAL0                   |   | 5  | 24 |   | ĪP    |
| DAL1                   | D | 6  | 23 |   | TR00  |
| DAL2                   |   | 7  | 22 |   | WD    |
| DAL3                   |   | 8  | 21 | 白 | WG    |
| DAL4                   |   | 9  | 20 | þ | МО    |
| DAL5                   |   | 10 | 19 | 白 | RD    |
| DAL6                   |   | 11 | 18 | 白 | CLK   |
| DAL7                   |   | 12 | 17 | 口 | DIRC  |
| MR                     |   | 13 | 16 | 白 | STEP  |
| GND                    |   | 14 | 15 | þ | VCC   |

The drive side of the interface needs no additional logic except for buffers/receivers. Designed for 5 1/4-inch single-or double-density operation, the device contains a programmable Motor On signal.

The VL1772-02 is implemented in NMOS silicon gate technology and is available in a 28-pin dual-in-line package. It is a low-cost version of the WD179X Floppy Disk Controller/Formatter and is compatible with generic 179X types. It also has a built-in digital data separator and write precompensation circuits. A single read line (RD, pin 19) is the only input required to recover serial FM or MFM data from the disk drive. The device has been specifically designed for control of 5 1/4-inch floppy disk

drives with data rates of 125K bits/s (single density) and 250K bits/s (double density). In addition, it can write a precompensation that is125 ns from nominal, and can be enabled at any point through simple software commands. Another programmable feature, Motor On, has been incorporated to automatically enable the spindle motor prior to operating a selected drive. The VL1772-02 offers stepping rates of 2, 3, 6, and 12 ms.

The processor interface consists of an 8-bit bidirectional bus for transfer of status, data, and commands. All host communication with the drive occurs through these data lines. They are capable of driving one standard TTL load or three LS loads.

## **BLOCK DIAGRAM**



(DAL)

#### **ORDER INFORMATION**

DDEN

| Part<br>Number | Package                     |
|----------------|-----------------------------|
| VL1772-02PC    | Plastic DIP                 |
| VL1772-02QC    | Plastic Leaded Chip Carrier |
| VL1772-02CC    | Ceramic DIP                 |
| Note:          |                             |

Operating temperature range: 0°C to +70°C.



## SIGNAL DESCRIPTIONS

| Signal<br>Name | Pin<br>Number | Signal<br>Descrip                                                                                                                                                                                                  | otion                               |                                      |                                                             |                                                    |  |
|----------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|--------------------------------------|-------------------------------------------------------------|----------------------------------------------------|--|
| CS             | 1             | Chip Se<br>with the                                                                                                                                                                                                | lect - A logic lo<br>device.        | ow on this input                     | selects the chip and enab                                   | les host communication                             |  |
| R∕₩            | 2             | Read/Write - A logic high on this input controls the placement of data on the $\overline{D0}$ - $\overline{D7}$ lines from a selected register, while a logic low causes a write operation to a selected register. |                                     |                                      |                                                             |                                                    |  |
| A0, A1         | 3, 4          | Address                                                                                                                                                                                                            | s 0, 1 - These t                    | wo inputs sele                       | ct a register to read or write                              | ə data:                                            |  |
|                |               | cs                                                                                                                                                                                                                 | A1                                  | A0                                   | R/₩ = 1                                                     | R/₩ = 0                                            |  |
|                |               | 0                                                                                                                                                                                                                  | 0                                   | 0                                    | Status Register                                             | Command Register                                   |  |
|                |               | 0                                                                                                                                                                                                                  | 0                                   | 1                                    | Track Register                                              | Track Register                                     |  |
|                |               | 0                                                                                                                                                                                                                  |                                     | 0                                    | Sector Register                                             | Sector Register                                    |  |
|                |               | <u>u</u>                                                                                                                                                                                                           |                                     | 1                                    | Data Register                                               | Data Register                                      |  |
| DAL0 - DAL7    | 5 - 12        | Data Ac<br>control,                                                                                                                                                                                                | cess Lines 0 to<br>or status. This  | hrough 7 - Eigh<br>s bus is enable   | nt-bit bidirectional bus used<br>d by CS and R/W. Each li   | d for transfer of data,<br>ne drives one TTL load. |  |
| MR             | 13            | Master<br>register                                                                                                                                                                                                 | Reset - A logic<br>(internal pull-u | : low pulse on t<br>p).              | his line resets the device a                                | nd initializes the status                          |  |
| GND            | 14            | Ground                                                                                                                                                                                                             | - Ground                            |                                      |                                                             |                                                    |  |
| VCC            | 15            | Power S                                                                                                                                                                                                            | Supply - +5 V ±                     | 5% power sup                         | polv input.                                                 |                                                    |  |
| STEP           | 16            | Step - T<br>pulse to                                                                                                                                                                                               | he Step outputte                    | t contains a pu                      | lse for each step of the dri                                | ve's R/ $\overline{W}$ head. This is a             |  |
| DIRC           | 17            | Directio<br>diskette                                                                                                                                                                                               | n - The Directi<br>, and low whe    | on output is hig<br>n stepping out.  | gh when stepping in toward                                  | ds the center of the                               |  |
| CLK            | 18            | Clock -<br>MHz ±1                                                                                                                                                                                                  | This input requ<br>%.               | uires a free-run                     | ning 50% duty cycle clock                                   | (for internal timing) at 8                         |  |
| RD             | 19            | Read D<br>pulses f                                                                                                                                                                                                 | ata - This activ<br>rom the drive.  | ve-low input is t                    | the raw data line containing                                | y both clock and data                              |  |
| МО             | 20            | Motor C<br>stepping                                                                                                                                                                                                | on - Active high<br>g operations.   | n output used to                     | o enable the spindle motor                                  | prior to read, write, or                           |  |
| WG             | 21            | Write G                                                                                                                                                                                                            | ate - This outp                     | ut is made vali                      | d prior to writing on the dis                               | kette.                                             |  |
| WD             | 22            | Write D<br>diskette                                                                                                                                                                                                | ata - FM or MF                      | M clock and d                        | ata pulses are placed on th                                 | nis line to be written on the                      |  |
| TROO           | 23            | Track 0<br>position                                                                                                                                                                                                | 0 - This active-<br>ed over Track   | low input infor<br>zero (internal)   | ms the VL1772-02 that the oull-up).                         | drive's $R/\overline{W}$ heads are                 |  |
| IP             | 24            | Index P<br>has bee                                                                                                                                                                                                 | ulse - This acti<br>en encountered  | ve-low input in<br>d on the diskett  | forms the VL1772-02 whe<br>te (internal pull-up).           | n the physical index hole                          |  |
| WPRT           | 25            | Write Pr<br>on this I                                                                                                                                                                                              | rotect - This ing<br>ine prevents a | out is sampled<br>ny Write Comr      | whenever a Write Comma<br>nand from executing (inter        | nd is received. A logic low nal pull-up).          |  |
| DDEN           | 26            | Double<br>When Ē                                                                                                                                                                                                   | Density Enabl<br>DEN = 0, doui      | e - This input p<br>ble density is s | in selects either single (FN<br>elected (internal pull-up). | 1) or double (MFM) density.                        |  |
| DRQ            | 27            | Data Re<br>or empt                                                                                                                                                                                                 | equest - This a<br>y (on a Write) ( | ctive-high outp<br>operation.        | out indicates that the Data I                               | Register is full (on a Read)                       |  |
| INTRQ          | 28            | Interrup<br>read of                                                                                                                                                                                                | t Request - Th<br>the Status Reg    | is active-high o<br>gister.          | putput is set at the complet                                | ion of any command or a                            |  |

# VL1772-02

## ARCHITECTURE

TheVL1772-02 Floppy Disk Controller/Formatter block diagram is illustrated on the front page. The primary sections include the parallel processor interface and the floppy disk interface.

Data Shift Register - This 8-bit register assembles serial data from the Read Data input (RD) during read operations and transfers serial data to the Write Data output during write operations.

Data Register - This 8-bit register is used as a holding register during disk read and write operations. In disk read operations, the assembled data byte is transferred in parallel to the Data Register from the Data Shift Register. In disk write operations, information is transferred in parallel from the Data Register to the Data Shift Register.

When executing the Seek command, the Data Register holds the address of the desired track position. This register is loaded from the Data Access Lines (DAL) and gated onto the DAL under processor control.

Track Register - This 8-bit register holds the track number of the current read/write head position. It is incremented by one every time the head is stepped in and decremented by one every time the head is stepped out (towards Track 00). The contents of the register are compared with the recorded track number in the ID field during disk read, write, and verify operations. The Track Register can be loaded from or transferred to the DAL. This register should not be loaded when the device is busy.

Sector Register (SR) - This 8-bit register holds the address of the desired sector position. The contents of the register are compared with the recorded sector number in the ID field during disk read or write operations. The Sector Register contents can be loaded from or transferred to the DAL. This register should not be loaded when the device is busy.

Command Register (CR) - This 8-bit register holds the command presently being executed. This register should not be loaded when the device is busy, unless the new command is a forced interrupt. The Command Register can be loaded from the DAL but not read onto the DAL.

Status Register (STR) - This 8-bit register holds device status information. The meaning of the status bits is a function of the type of command previously executed. This register can be read onto the DAL but not loaded from the DAL.

CRC Logic - This logic is used to check or to generate the 16-bit cyclic redundancy check (CRC). The polynomial is:

 $G(x) = x^{16} + x^{12} + x^5 + 1$ 

The CRC includes all information starting with the address mark and up to the CRC characters. The CRC register is preset to ones prior to data being shifted through the circuit.

Arithmetic/Logic Unit (ALU) - The ALU is a serial comparator, incrementer, and decrementer and is used for register modification and comparisons with the disk-recorded ID field.

Timing and Control - All computer and floppy disk interface controls are generated through this logic. The internal device timing is generated from an external crystal clock. The VL1772-02 has two different modes of operation according to the state of DDEN: When DDEN = 0, double density (MFM) is enabled. When DDEN = 1, single density is enabled.

Address Mark Detector - The AM detector detects ID, data, and index address marks during read and write operations.

Data Separator - A digital data separator, consisting of a ring shift register and data window detection logic, provides read data and a recovery clock to the AM detector.

#### FIGURE 1. SYSTEM BLOCK DIAGRAM





#### FUNCTIONAL DESCRIPTION PROCESSOR INTERFACE

The interface to the processor is accomplished through the eight data access lines (DALs) and associated control signals. The DALs are used to transfer data, status, and control words out of, or into the VL1772-02. The DALs are three-state buffers that are enabled as output drivers when Chip Select  $(\overline{CS})$ = 0 and  $\overline{RW}$  = 1 are active, or act as input receivers when  $\overline{CS}$  and  $\overline{RW}$  = 0 are active.

When transfer of data with the Floppy Disk Controller is required by the host processor, the device address is decoded and  $\overline{CS}$  is made low. The address bits A1 and A0, combined with the signal  $\overline{R/W}$  during a read or write operation, are interpreted as selecting the following registers: sector is reached.

On disk write operations, the Data Request is activated when the Data Register transfers its contents to the Data Shift Register, and requires a new data byte. It is reset when the Data Register is loaded with new data by the processor. If new data is not loaded at the time the next serial byte is required by the floppy disk, a byte of zeros is written on the diskette and the Lost Data bit is set in the Status Register.

At the completion of every command an INTRQ is generated; it is reset by either reading the status register or by loading the command register with a new command. In addition, INTRQ is generated if a Force Interrupt command condition is met.

| A1 | - A0 | READ ( $R/\overline{W} = 1$ ) | WRITE (R/ $\overline{W} = 0$ ) |
|----|------|-------------------------------|--------------------------------|
| 0  | 0    | Status Register               | Command Register               |
| 0  | 1    | Track Register                | Track Register                 |
| 1  | 0    | Sector Register               | Sector Register                |
| 1  | 1    | Data Register                 | Data Register                  |

After any register is written to, the same register cannot be read from until  $16 \,\mu s$  in MFM or  $32 \,\mu s$  in FM have elapsed.

During direct memory access (DMA) types of data transfers between the Data Register of the VL1772-02 and the processor, the Data Request (DRQ) output is used in data transfer control. This signal also appears as status bit 1 during read and write operations.

On disk read operations, the Data Request is activated (set high) when an assembled serial input byte is transferred in parallel to the Data Register. This bit is cleared when the Data Register is read by the processor. If the Data Register is read after one or more characters are lost, by having new data transferred into the register prior to processor readout, the Lost Data bit is set in the Status Register. The read operation continues until the end of The VL1772-02 has two modes of operation, according to the state of DDEN. When DDEN = 1, single density is selected. In either case, the CLK input is at 8 MHz.

#### GENERAL DISK READ OPERATIONS

Sector lengths of 128, 256, 512, or 1024 bytes are obtainable in either FM or MFM formats. For FM, DDEN should be placed to logical "1". For MFM formats, DDEN should be placed to a logical "0".

Sector lengths are determined at format time by the fourth byte in the "ID" field.

| SECTOR LENGTH TABLE          |                                        |  |  |  |  |
|------------------------------|----------------------------------------|--|--|--|--|
| SECTOR LENGTH<br>FIELD (HEX) | NUMBER OF BYTES<br>IN SECTOR (DECIMAL) |  |  |  |  |
| 00                           | 128                                    |  |  |  |  |
| 01                           | 256                                    |  |  |  |  |
| 02                           | 512                                    |  |  |  |  |
| 03                           | 1024                                   |  |  |  |  |

There are from 0 to 244 sectors per track for the VL1772-02, and from 0 to 244 tracks.

#### GENERAL DISK WRITE OPERATION

When writing is to take place on the disk the Write Gate (WG) output is activated, allowing current to flow into the read/write head. As a precaution to erroneous writing, the first data byte must be loaded into the Data Register in response to a Data Request from the device before the Write Gate signal can be activated.

Writing is inhibited when the Write Protect input is a logic low, in which case any Write command is immediately terminated, an interrupt is generated, and the Write Protect status bit is set.

For write operations, the VL1772-02 provides Write Gate to enable a write condition, and Write Data which consists of a series of active-high pulses. These pulses contain both clock and data information in FM and MFM. Write Data provides the unique missing clock patterns for recording address marks.

The Precompensation Enable bit in Write commands allow automatic write precompensation to take place. The outgoing write data stream is delayed or advanced from nominal by 187ns according to the following table:

| 1        | PATT | ERN |   | MFM                                                                        | FM                             |
|----------|------|-----|---|----------------------------------------------------------------------------|--------------------------------|
| X        | 1    | 1   | 0 | Early                                                                      | N/A                            |
| Х        | 0    | 1   | 1 | Late                                                                       | N/A                            |
| 0        | 0    | 0   | 1 | Early                                                                      | N/A                            |
| 1        | 0    | 0   | 0 | Late                                                                       | N/A                            |
| <b>A</b> |      |     |   | <ul> <li>Next Bit to</li> <li>Current Bit</li> <li>Previous Bit</li> </ul> | be sent<br>sending<br>its sent |

Precompensation is typically enabled on the innermost tracks where bit shifts usually occur and bit density is at its maximum.

## COMMANDS

The VL1772-02 accepts eleven commands. Command words should only be loaded in the Command Register when the Busy Status Bit is off (Status Bit 0). The one exception is the Force Interrupt command. Whenever a command is being executed, the Busy Status Bit is set. When a command is completed, an interrupt is generated and the Busy status bit is reset. The Status Register indicates whether the completed command encountered an error or was fault-free. For ease of discussion, commands are divided into four types and are summarized in Table 1.

The Type I Commands (see Figure 2) include the Restore, Seek, Step, Stepin, and Step-out commands. Each of the Type I Commands contains a rate field (r0, r1), which determines the stepping motor rate.

A 4 µs (MFM) or 8 µs (FM) pulse is provided as an output to the drive. For every step pulse issued, the drive moves one track location in a direction determined by the direction output. The chip will step the drive in the same direction it last stepped unless the command changes the direction.

The Direction signal is active-high when stepping in and low when stepping out. The Direction signal is valid 24  $\mu$ s before the first stepping pulse is generated.

After the last directional step, an additional 30 ms of head settling time takes place if the Verify flag is set in Type I commands. There is also a 30 ms head settling time if the E flag is set in any Type II or III command. When a Seek, Step, or Restore command is executed, an optional verification of read/write head position can be performed by setting bit 2(V = 1)in the command word to logic 1. The verification operation begins at the end of the 30 ms settling time after the head is loaded against the media. The track number from the first encountered ID Field is compared against the contents of the Track Register. If the track



numbers compare and the ID Field cyclic redundancy check (CRC) is correct, the verify operation is complete and an INTRQ is generated with no errors. If there is a match but not a valid CRC, the CRC Error Status Bit is set (Status Bit 3), and the next encountered ID field is read from the disk for the verification operation.

The VL1772-02 must find an ID field with correct track number and correct CRC within five revolutions of the media, otherwise, the seek error is set and an INTRQ is generated. If V = 0, no verification is performed.

All commands, except the Force Interrupt command, may be programmed via the h Flag to delay for spindle motor start up time. If the h Flag is not set and the Motor On line is low when a command is received, the VL1772-02 will force Motor On to a logic 1 and waits six revolutions before executing the command. At 300 RPM, this guarantees a one-second spindle start-up time. If, after finishing the command, the device

## **TABLE 1. COMMAND SUMMARY**

| the second s |   | _ |   |   | -   |   |                | _  |
|----------------------------------------------------------------------------------------------------------------|---|---|---|---|-----|---|----------------|----|
|                                                                                                                |   |   |   | В | ITS |   |                |    |
| TYPE COMMAND                                                                                                   | 7 | 6 | 5 | 4 | 3   | 2 | 1              | 0  |
| I Restore                                                                                                      | 0 | 0 | 0 | 0 | h   | ٧ | r <sub>1</sub> | ro |
| I Seek                                                                                                         | 0 | 0 | 0 | 1 | h   | V | r.             | rő |
| I Step                                                                                                         | 0 | 0 | 1 | u | h   | V | r              | rő |
| I Step-in                                                                                                      | 0 | 1 | 0 | u | h   | ۷ | r              | rő |
| I Step-out                                                                                                     | 0 | 1 | 1 | u | h   | ۷ | ŕ              | ro |
| II Read Sector                                                                                                 | 1 | 0 | 0 | m | h   | Е | 0              | Ő  |
| II Write Sector                                                                                                | 1 | 0 | 1 | m | h   | Е | Р              | an |
| III Read                                                                                                       |   |   |   |   |     |   |                | v  |
| Address                                                                                                        | 1 | 1 | 0 | 0 | h   | Е | 0              | 0  |
| III Read Track                                                                                                 | 1 | 1 | 1 | 0 | h   | Е | 0              | 0  |
| III Write Track                                                                                                | 1 | 1 | 1 | 1 | h   | Е | Р              | 0  |
| IV Force                                                                                                       |   |   |   |   |     |   |                |    |
| Interrupt                                                                                                      | 1 | 1 | 0 | 1 | 6   | 6 | - La           | 6  |

#### FLAG SUMMARY

#### TYPE I COMMANDS

- h = Motor On Flag (Bit 3)
- h = 0, Enable Spin-up Sequence
- h = 1, Disable Spin-up Sequence
- V = Verify Flag (Bit 2)
- V = 0, No Verify V = 1, Verify on Destination Track
- v = i, veiny on Destination mac

| $r_1, r_0 =$   | Stepp          | ing Rate (Bits 1,0 | )       |
|----------------|----------------|--------------------|---------|
| r <sub>1</sub> | r <sub>o</sub> |                    | 1772-02 |
| 0              | 0              |                    | 6 ms    |
| 0              | 1              |                    | 12 ms   |
| 1              | 0              |                    | 2 ms    |
| 1              | 1              |                    | 3 ms    |
|                |                |                    |         |

- u = Update Flag (Bit 4)
- u = 0, No Update
- u = 1, Update Track Register

| m = Multiple Sector Flag (Bit 4)                                  |
|-------------------------------------------------------------------|
| m = 0, Single Sector<br>m = 1, Multiple Sector                    |
| H = Motor On Flag (Bit 3)                                         |
| H = 0, Enable Spin Up Sequence<br>H = 1, Disable Spin Up Sequence |
| a <sub>0</sub> = Data Address Mark (Bit 0)                        |
| $a_0 = Write Normal Data Mark a_0 = 1, Write Deleted Data Mark$   |
| E = 15ms Settling Delay (Bit 2)                                   |
| E = 0, No Delay<br>E = 1, Add 15ms Delay                          |
| P = Write Precompensation (Bit 1)                                 |
| P = 0,Enable Write Precomp<br>P = 1,Disable Write Precomp         |

TYPE II & III COMMANDS

| TYPE IV COMMANDS                                              |   |
|---------------------------------------------------------------|---|
| I <sub>3</sub> -I <sub>0</sub> Interrupt Condition (Bits 3-0) |   |
| I <sub>0</sub> = 1, Not Used                                  |   |
| $I_1 = 1$ , Not Used                                          |   |
| $I_2 = 1$ , Interrupt on Index Pulse                          |   |
| $I_3 = 1$ , Immediate Interrupt                               |   |
| Internet a state without interrupt                            | • |



remains idle for ten revolutions, the Motor On line goes back to a logic 0. If a command is issued while Motor On is high, the command executes immediately, defeat-ing the sixrevolution start up. This feature allows consecutive read or write commands without waiting for each motor start-up; the VL1772-02 assumes the spindle motor is up to speed.

#### **RESTORE (SEEK TRACK 0)**

Upon receipt of this command, the Track 00 (TR00) input is sampled. If TR00 is active-low indicating the read/write head is positioned over Track 00, the Track Register is loaded with zeros and an interrupt is generated. If TR00 is not active-low, stepping pulses (pin 16) at a rate specified by the r1, r0 field are issued until the TR00 input is activated. At this time, the Track Register is loaded with zeros and an interrupt is generated. If the TR00 input does not go active-low after 255 stepping pulses, the VL1772-02 terminates operation, interrupts, and sets the Seek Error Status Bit, providing the V flag is set. A verification operation also takes place if the V flag is set. The h bit allows the Motor On option at the start of command.





4–16



#### FIGURE 3. TYPE II COMMAND FLOWCHART

FIGURE 2. TYPE I COMMAND FLOWCHART (Cont.)







#### SEEK

This command assumes that the Track Register contains the track number of the current position of the read/write head and the Data Register contains the desired track number. The VL1772-02 will update the Track Register and issue stepping pulses in the appropriate direction until the contents of the Track Register are equal to the contents of the Data Register (the desired track location). A verification operation takes place if the V flag is on. The h bit allows the Motor On option at the start of the command. An interrupt is generated at the completion of the command. ( Note: When using multiple drives, the track register must be updated for the drive selected before seeks are issued.)

#### STEP

Upon receipt of this command, the VL1772-02 issues one stepping pulse to the disk drive. The stepping motor direction is the same as in the previous step command. After a delay determined by the r1, r0 field, a verification takes place if the V flag is on. If the U flag is on, the Track Register is updated. The h bit allows the Motor On option at the start of the command. An interrupt is generated at the completion of the command.

#### STEP-IN

Upon receipt of this command, the VL1772-02 issues one stepping pulse in the direction towards track 76. If the U flag is on, the Track Register is incremented by one. After a delay is determined by the r1, r0 field, a verification takes place if the V flag is on. The h bit allows the Motor On option at the start of the command. An interrupt is generated at the completion of the command.

#### STEP-OUT

Upon receipt of this command, the VL1772-02 issues one stepping pulse in the direction towards track 0. If the U flag is on, the Track Register is decremented by one. After a delay determined by the r1, r0 field, a verification takes place if the V flag is on. The h bit allows the Motor On option at the start of the command. An interrupt is generated at the completion of the command.

#### TYPE II COMMANDS

The Type II Commands (see Figure 3) are the Read Sector and Write Sector commands. Prior to loading the Type II Command into the Command Register, the computer must load the Sector Register with the desired sector number. Upon receipt of the Type II command, the busy status bit is set. If the E flag = 1, the command executes after a 15 ms delay.

When an ID field is located on the disk, the VL1772-02 compares the track number on the ID field with the Track Register. If there is not a match, the next encountered ID field is read and a comparison is again made. If there was a match, the sector number of the ID field is compared with the Sector Register. If there is not a sector match, the next encountered ID field is read off the disk and comparisons again made. If the ID field CRC is correct, the data field is then located and is either written into or read from depending upon the command. The VL1772-02 must find an ID field with a track number, sector number, and CRC within four revolutions of the disk; otherwise, the Record Not Found Status Bit is set (Status Bit 4) and the command is terminated with an interrupt (INTRQ).

Each of the Type II Commands contains an m flag that determines if multiple records (sectors) are to be read or written, depending upon the command. If m = 0, a single sector is read or written and an interrupt is generated at the completion of the command. If m = 1, multiple records are read or written with the sector register internally updated so that an address verification can occur on the next record. The VL1772-02 continues to read or write multiple records and update the sector register in numerical ascending sequence until the sector register exceeds the number of sectors on the track or until the Force Interrupt command is loaded into the Command Register, which terminates the command and generates an interrupt.

For example: if the VL1772-02 is instructed to read sector 27 and there are only 26 sectors on the track, the sector register exceeds the number available. The VL1772-02 will search for five disk revolutions, interrupt out, reset busy, and set the Record Not Found Status Bit.

#### READ SECTOR

Upon receipt of the Read Sector command, the Busy status bit is set. and when an ID field is encountered that has the correct track number, correct sector number, and correct CRC, the data field is presented to the computer. The data address mark (DAM) of the data field must be found within 30 bytes in single density and 43 bytes in double density of the last ID field CRC byte: if not, the ID field is searched for and verified again followed by the data address mark search. If, after five revolutions the DAM cannot be found. the Record Not Found StatusBit is set and the operation is terminated. When the first character or byte of the data field has been shifted through the DSR, it is transferred to the DR, and DRQ is generated. If the computer has not read the previous contents of the DR before a new character is transferred, that character is lost and the Lost Data Status bit is set. This sequence continues until the complete data field has been input to the computer. If there is a CRC error at the end of the data field, the CRC Error Status Bit is set. and the command is terminated (even if it is a multiple record command). At the end of the read operation, the type of data address mark encountered in the data field is recorded in the Status Register (Bit 5) as shown:

| STATUS BIT 5 |                   |
|--------------|-------------------|
| 1            | Deleted Data Mark |
| 0            | Data Mark         |

#### WRITE SECTOR

Upon receipt of the Write Sector command, the Busy status bit is set. When an ID field is encountered that has the correct track number, correct sector number, and correct CRC, a DRQ is generated. The VL1772-02 counts off 11 bytes in single density and 22 bytes in double density from the CRC field and the Write Gate (WG) output is made active if the DRQ is serviced (i.e., the DR has been loaded by the computer). If DRQ has not been serviced, the command is terminated and the Lost Data status bit is set. If the DRQ has been serviced, the WG is made active and six bytes of zeros in single density and 12 bytes in double density are then written on the disk. At this time, the



#### FIGURE 3. TYPE II COMMAND FLOWCHART (Cont.)





#### FIGURE 3. TYPE II COMMAND FLOWCHART (Cont.)



4-20



#### FIGURE 3. TYPE II COMMAND FLOWCHART (Cont.)





data address mark is then written on the disk as determined by the a0 field of the command as shown below:

| a <sub>0</sub> | DATA ADDRESS MARK (BIT 0) |
|----------------|---------------------------|
| 1              | Deleted Data Mark         |
| 0              | Data Mark                 |

The VL1772-02 then writes the data field and generates DRQs to the computer. If the DRQ is not serviced in time for continuous writing, the Lost Data Status Bit is set and a byte of zeros is written on the disk. The command is not terminated. After the last data byte has been written on the disk, the two-byte CRC is computed internally and written on the disk followed by one byte of logic ones in FM or in FMF. The WG output is then deactivated. INTRQ will set 24 us (MFM) after the last CRC byte is written. For partial sector writing, the proper method is to write data and fill the balance with zeros.

#### **TYPE III COMMANDS**

Read Address - Upon receipt of the Read Address command, the Busy Status Bit is set. The next-encountered ID field is then read in from the disk, and six data bytes of the ID field are assembled and transferred to the DR, and a DRQ is generated for each byte. The six bytes of the ID field are shown below:

| TRACK | SIDE   | SECTOR | SECTOR | CRC | CRC |
|-------|--------|--------|--------|-----|-----|
| ADDR  | NUMBER | ADDR   | LENGTH | 1   | 2   |
| 1     | 2      | 3      | 4      | 5   | 6   |

Although the CRC characters are transferred to the computer, the VL1772-02 checks for validity and the CRC Error Status Bit is set if there is a CRC error. The track address of the ID field is written into the Sector Register so that a

#### WRITE TRACK FORMATTING THE DISK

comparison can be made by the user.

At the end of the operation an interrupt

Read Track - Upon receipt of the READ

track command, the head is loaded and

starts with the leading edge of the first

encountered index pulse and continues

header, and data bytes are assembled

and transferred to the Data Register and

DROs are generated for each byte. The

to each address mark encountered. An

interrupt is generated at the completion

characteristics that make it suitable for

diagnostic purposes. They are: no CRC

checking is performed; gap information

is included in the data stream: and the

duration of the command. Because the

AM detector is always on, write splices

or noise may cause the chip to look for

DAM, Data and Data CRC Bytes for each

The ID AM, ID Field, ID CRC Bytes,

sector will be correct. The Gap Bytes

may be read incorrectly during write-

splice time because of synchronization.

address mark detector is on for the

of the command.

an AM.

This command has several

accumulation of bytes is synchronized

is generated and the Busy status is

the Busy status bit is set. Reading

until the next index pulse. All gap,

reset.

Data and gap information are provided at the computer interface. Formatting the

disk is accomplished by positioning the  $R/\overline{W}$  head over the desired track number and issuing the Write Track command.

Upon receipt of the Write Track command, the Busy Status Bit is set. Writing starts with the leading edge of the first encountered index pulse and continues until the next index pulse, at which time the interrupt is activated. The Data Request is activated immediately upon receiving the command, but writing will not start until after the first byte has been loaded into the Data Register. If the DR has not been loaded within three byte times, the operation is terminated, making the device Not Busy, the Lost Data Status Bit is set, and the interrupt is activated. If a byte is not present in the DR when needed, a byte of zeros is substituted. This sequence continues from one index mark to the next index mark. Normally, whatever data pattern appears in the data register is written on the disk with a normal clock pattern. However, if the VL1772-02 detects a data pattern of F5 through FE in the data register, this is interpreted as a data address mark with missing clocks or CRC generation.

The CRC generator is initialized when any data byte from F8 to FE is about to be transferred from the DR to the DSR in FM or by receipt of F5 in MFM. An F7 pattern generates two CRC characters in FM or MFM. As a consequence, the patterns F5 through FE must not appear in the gaps, data fields, or ID fields. Also, CRCs must be generated by an F7 pattern.

Disks may be formatted in IBM 3740 or System 34 formats with sector lengths of 128, 256, 512, or 1024 bytes.

## **TABLE 2. DATA PATTERN DECODE**

| DATA PATTERN<br>IN DR (HEX) | IN FM (DDEN = 1)                   | IN MFM (DDEN = 0)             |
|-----------------------------|------------------------------------|-------------------------------|
| 00 thru F4                  | Write 00 thru F4 with CLK = FF     | Write 00 thru F4, in MFM      |
| F5                          | Not Allowed                        | Write A1* in MFM, Present CRC |
| F6                          | Not Allowed                        | Write C2** in MFM             |
| F7                          | Generate 2 CRC bytes               | Generate 2 CRC bytes          |
| F9 thru FB                  | Write F8 thru FB, CLK = C7, Preset |                               |
|                             | CRC                                | Write F8 thru FB, in MFM      |
| FC                          | Write FC with CLK = D7             | Write FC in MFM               |
| FD                          | Write FD with CLK = FF             | Write FD in MFM               |
| FE                          | Write FE, CLK = C7, Preset CRC     | Write FE in MFM               |
| FF                          | Write FF with CLK = FF             | Write FF in MFM               |

\*Missing clock transition between bits 4 and 5.

\*\*Missing clock transition between bits 3 and 4.



#### TYPE IV COMMANDS

The Forced Interrupt Command is generally used to terminate a multiple sector read or write command or to ensure Type I status in the status register. This command can be loaded into the command register at any time. If there is a current command under execution (Busy Status Bit set) the command is terminated and the Busy Status Bit reset.

The lower four bits of the command determine the conditional interrupt as follows:

- I0 = Don't Care
- I1 = Don't Care
- l2 = Every Index Pulse
- I3 = Immediate Interrupt

The conditional interrupt is enabled when the corresponding bit positions of the command (I3-I0) are set to a 1. Then, when the condition for interrupt is met. the INTRQ line goes high signifying that the condition specified has occurred. If I3-I0 are all set to zero (HEX D0), no interrupt occurs but any command presently under execution is immediately terminated. When using the immediate interrupt condition (I3 = 1) an interrupt immediately is generated and the current command terminated. Reading the Status or writing to the Command Register does not automatically clear the interrupt. The HEX D0 is the only command that enables the immediate interrupt (HEX D8) to clear on a subsequent load command register or read status register operation. Follow a HEX D8 with D0 command.

Wait 16 µs (double density) or 32 µs (single density) before issuing a new command after issuing a forced interrupt. Loading a new command sooner than this nullifies the forced interrupt.

Force Interrupt Command stops any command at the end of an internal micro instruction and generates INTRQ when the specified condition is met. Force Interrupt waits until ALU operations in progress are complete (CRC calculations, compares, etc.).

Status Register - Upon receipt of any command, except the Force Interrupt command, the Busy Status Bit is set and the rest of the status bits are updated or cleared for the new command. If the Force Interrupt Command is received when there is a current command under execution, the Busy status bit is reset, and the rest of the status bits are unchanged. If the Force Interrupt command is received when there is not a current command under execution, the Busy Status Bit is reset and the rest of the status bits are updated or cleared. In this case, Status reflects the Type I commands.

The user has the option of reading the status register through program control or using the DRQ line with DMA or interrupt methods. When the Data Register is read the DRQ bit in the Status Register and the DRQ line are automatically reset. A write to the Data Register also causes both DRQ's to reset.

The Busy Bit in the status may be monitored with a user program to determine when a command is complete, in lieu of using the INTRQ line. When using the INTRQ, a Busy status check is not recommended because a read of the Status Register to determine the condition of busy resets the INTRQ line.

The format of the Status Register is shown below:

|    | (BITS) |    |    |    |    |    |    |  |
|----|--------|----|----|----|----|----|----|--|
| 7  | 6      | 5  | 4  | 3  | 2  | 1  | 0  |  |
| S7 | S6     | S5 | S4 | S3 | S2 | S1 | SO |  |

Because of internal synchronization cycles, certain time delays are observed when operating under program I/O as shown.

| Operation                | Next Operation                  | Delay Req'd.<br>FM MFM |        |  |
|--------------------------|---------------------------------|------------------------|--------|--|
| Write to<br>Command Reg. | Read Busy Bit<br>(Status Bit 0) | 48µsec                 | 24µsec |  |
| Write to<br>Command Reg. | Read Status<br>Bits 1-7         | 64µsec                 | 32µsec |  |
| Write<br>Register        | Read Same<br>Register           | 32µsec                 | 16µsec |  |

Shown below is the recommended singledensity format with 128 bytes/sector. In order to format a diskette, the user must issue the Write Track command, and load the data register with the following values. For every byte to be written,

| NU | MBER  |                           |
|----|-------|---------------------------|
| OF | BYTES | HEX VALUE OF BYTE WRITTEN |
|    | 40    | FF (or 00)                |
|    | 6     | 00                        |
|    | 1     | FE (ID Address Mark)      |
|    | 1     | Track Number              |
|    | 1     | Side Number (00 or 01)    |
|    | 1     | Sector Number (1 thru 1A) |
|    | 1     | 00 (Sector Length)        |
|    | 1     | F7 (2 CRC's written)      |
|    | 11    | FF (or 00)                |
|    | 6     | 00                        |
|    | 1     | FB (Data Address Mark)    |
|    | 128   | Data (IBM uses E5)        |
|    | 1 🐪   | F7 (2 CRC's written)      |
|    | 10    | FF (or 00)                |
|    | 369** | FF (or 00)                |

there is one Data Request.

\*\*Continue writing until VL1772-02 interrupts out. Approximately 369 bytes.

#### 256 BYTES/SECTOR

Shown below is the recommended dualdensity format with 256 bytes/sector. In order to format a diskette, the user must issue the Write Track command and load the Data Register with the following values. For every byte to be written, there is one data request.

| NUMBER   |                           |
|----------|---------------------------|
| OF BYTES | HEX VALUE OF BYTE WRITTEN |
| 60       | 4E                        |
| 12       | 00                        |
| 3        | F5 (Writes A1)            |
| 1        | FE (ID Address Mark)      |
| 1        | Track Number (0 thru 4C)  |
| 1        | Side Number (0 or 1)      |
| 1        | Sector Number (1 thru 1A) |
| 1        | 01 (Sector Length)        |
| 1        | F7 (2 CRC's written)      |
| 22       | 4E                        |
| 12       | 00                        |
| 3        | F5 (Writes A1)            |
| 1        | FB (Data Address Mark)    |
| 256      | DATA                      |
| 1        | F7 (Data Address Mark)    |
| 24       | 4E                        |
| 668**    | 4E                        |

\*\* Continue writing until VL1772-02 interrupts out. Approximately 668 bytes.

Non-Standard Formats - Variations in the recommended formats are possible to a limited extent, if the following requirements are met:

- 1) Sector size must be 128, 256, 512, or 1024 bytes.
- 2) Gap 2 cannot be varied from the recommended format.
- 3) Three bytes of A1 must be used in MFM.



In addition, the Index Address Mark is not required for operation by the VL1772-02. Gap 1, 3, and 4 can be as short as two bytes for VL1772-02 operation; however, PLL lock-up time, motor speed variation, write-splice area, etc., add more bytes to each gap to achieve proper operation. For highest system reliability, use the recommended format.

|           | FM          | MFM         |
|-----------|-------------|-------------|
| Gap I     | 16 bytes FF | 32 bytes 4E |
| Gap II    | 11 bytes FF | 22 bytes 4E |
| *         | 6 bytes 00  | 12 bytes 00 |
| *         | •           | 3 bytes A1  |
| Gap III** | 10 bytes FF | 24 bytes 4E |
| •         | 4 bytes 00  | 8 bytes 00  |
|           | •           | 3 bytes A1  |
| Gap IV    | 16 bytes FF | 16 bytes 4E |

\*Byte counts must be exact. \*\*Byte counts are minimum, except exactly 3 bytes of A1 must be written.

## **TABLE 3. STATUS REGISTER**

| BIT NAME                     | MEANING                                                                                                                                                                                                                                              |
|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| S7 MOTOR ON                  | This bit reflects the status of the Motor On output.                                                                                                                                                                                                 |
| S6 WRITE PROTECT             | On Read Record: Not Used. On Read Track: Not Used. On any Write: It indicates a Write Protect. This bit is reset when updated.                                                                                                                       |
| S5 RECORD<br>TYPE/SPIN-UP    | When set, this bit indicates that the Motor Spin-Up sequence has completed (5 revolutions) on Type I commands. Type 2 & 3 commands, this bit indicates record Type. $0 = Data$ Mark. $1 = Deleted Data$ Mark.                                        |
| S4 RECORD NOT<br>FOUND (RNF) | When set, it indicates that the desired track, sector, or side were not found. This bit is reset when updated.                                                                                                                                       |
| S3 CRC ERROR                 | If S4 is set, an error is found in one or more ID fields; otherwise it indicates error data field. This bit is reset when updated.                                                                                                                   |
| S2 LOST DATA/<br>BYTE        | When set, it indicates the computer did not respond to DRQ in one byte time.<br>This bit is reset to zero when updated. On Type I commands, this bit reflects the<br>status of the TR00 signal.                                                      |
| S1 DATA REQUEST<br>INDEX     | This bit is a copy of the DRQ output. When set, it indicates the DR is full on a Read Operation or the DR is empty on a Write operation. This bit is reset to zero when updated. On Type 1 commands, this bit indicates the status of the IP signal. |
| SO BUSY                      | When set, command is under execution. When reset, no command is under execution.                                                                                                                                                                     |



#### FIGURE 4. TYPE III COMMAND WRITE TRACK FLOWCHART





#### FIGURE 4. TYPE III COMMAND WRITE TRACK FLOWCHART (Cont.)





## TABLE 4. READ DATA TIMING

| CHARACTERISTIC       | MIN          | ТҮР | MAX | UNITS | CONDITIONS |
|----------------------|--------------|-----|-----|-------|------------|
| Raw Read Pulse Width | .200<br>.400 |     | 3   | µsec  | MFM<br>FM  |
| Raw Read Cycle Time  | 3            |     | -   | μsec  |            |

## TABLE 5. READ ENABLE TIMING

## **READ ENABLE TIMING** – $\overline{\text{RE}}$ such that: $R/\overline{W} = 1$ , CS = 0.

| SYMBOL           | CHARACTERISTIC       | MIN | ТҮР | MAX | UNITS | CONDITIONS                      |
|------------------|----------------------|-----|-----|-----|-------|---------------------------------|
| t <sub>RE</sub>  | RE Pulse Width of CS | 200 |     |     | nsec  | $C_L = 50 \text{ pf}$           |
| t <sub>DRR</sub> | DRQ Reset from RE    |     | 200 | 300 | nsec  |                                 |
| t <sub>DV</sub>  | Data Valid from RE   |     | 100 | 200 | nsec  | $C_L = 50 \text{ pf}$           |
| t <sub>DOH</sub> | Data Hold from RE    | 20  |     | 150 | nsec  | $\overline{C_1} = 50 \text{pf}$ |
|                  | INTRQ Reset from RE  |     |     | 8   | μsec  |                                 |

Note: Worst case service time for DRQ is 23.5  $\mu$ sec for MFM and 47.5  $\mu$ sec for FM.

#### FIGURE 5. READ ENABLE TIMING





## TABLE 6. WRITE ENABLE TIMING

## WRITE ENABLE TIMING – $\overline{WE}$ such that: $R/\overline{W} = 0$ , $\overline{CS} = 0$ .

| SYMBOL           | CHARACTERISTIC      | MIN | ТҮР | MAX | UNITS | CONDITIONS |
|------------------|---------------------|-----|-----|-----|-------|------------|
| t <sub>AS</sub>  | Setup ADDR to CS    | 50  |     |     | nsec  |            |
| t <sub>SET</sub> | Setup R/W to CS     | 0   |     |     | nsec  |            |
| t <sub>AH</sub>  | Hold ADDR from CS   | 10  |     |     | nsec  |            |
| t <sub>HLD</sub> | Hold R/W from CS    | 0   |     |     | nsec  |            |
| twe              | WE Pulse Width      | 200 |     |     | nsec  |            |
| tDRW             | DRQ Reset from WE   |     | 100 | 200 | nsec  |            |
| t <sub>DS</sub>  | Data Setup to WE    | 150 |     |     | nsec  |            |
| t <sub>DH</sub>  | Data Hold from WE   | 0   |     |     | nsec  |            |
|                  | INTRQ Reset from WE |     |     | 8   | μsec  |            |

#### FIGURE 6. WRITE ENABLE TIMING





## TABLE 7. WRITE DATA TIMING

| SYMBOL | CHARACTERISTIC           | MIN | ТҮР   | MAX | UNITS | CONDITIONS  |
|--------|--------------------------|-----|-------|-----|-------|-------------|
|        | Write Gate to Write Data |     | 4     |     | μsec  | FM          |
|        |                          |     | 2     | }   | μsec  | MFM         |
|        | Write Data Cycle Time    |     | 4,6,8 |     | μsec  |             |
|        | Write Gate off from WD   |     | 4     |     | μsec  | FM          |
|        |                          |     | 2     |     | usec  | MFM         |
| twp    | Write Data Pulse Width   |     | 820   |     | nsec  | Early MFM   |
|        |                          |     | 690   |     | nsec  | Nominal MFM |
|        |                          |     | 570   |     | nsec  | Late MFM    |
|        |                          |     | 1.38  |     | μsec  | FM          |

#### FIGURE 7. WRITE DATA TIMING





## TABLE 8. MISCELLANOUS TIMING

| SYMBOL           | CHARACTERISTIC                                                                                                   | MIN | ТҮР | MAX | UNITS | CONDITIONS |
|------------------|------------------------------------------------------------------------------------------------------------------|-----|-----|-----|-------|------------|
| t <sub>CD1</sub> | Clock Duty (low)                                                                                                 | 50  | 67  |     | nsec  |            |
| t <sub>CD2</sub> | CLock Duty (high)                                                                                                | 50  | 67  |     | nsec  |            |
| t <sub>STP</sub> | Step Pulse Output                                                                                                | 1   | 4   | }   | μsec  | MFM        |
| 011              |                                                                                                                  |     | 8   |     |       | FM         |
| t <sub>DIB</sub> | Dir Setup to Step                                                                                                |     | 24  |     | μsec  | MFM        |
| 2                | and the second |     | 48  |     |       | FM         |
| t <sub>MB</sub>  | Master Reset Pulse Width                                                                                         | 50  |     |     | μsec  |            |
| t <sub>IP</sub>  | Index Pulse Width                                                                                                | 20  |     |     | μsec  |            |

FIGURE 8. MISCELLANOUS TIMING





#### FIGURE 9. FORMATS



#### DOUBLE DENSITY FORMAT

## **ABSOLUTE MAXIMUM RATINGS**

| Ambient Operating                     |                  |
|---------------------------------------|------------------|
| Temperature                           | -10°C to +80°C   |
| Storage Temperature                   | -65°C to +140°C  |
| Supply Voltage to<br>Ground Potential | -0.5 V to +7.0 V |
| Applied Output<br>Voltage             | -0.5 V to +7.0 V |
| Applied Input<br>Voltage              | -0.5 V to +7.0 V |
| Power Dissipation                     | 800mW            |
|                                       |                  |

Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only. Functional operation of this device at these or other conditions above those indicated in the operational sections of this specification is not implied and exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## DC CHARACTERISTICS TA = 0°C to 70°C, VCC = 5 v $\pm$ 5%

| Symbol | Parameter                | Min | Тур | Max  | Unit | Conditions   |
|--------|--------------------------|-----|-----|------|------|--------------|
| VOH    | Output High Voltage      | 2.4 |     |      | v    | IO = -100 μA |
| VOL    | Output Low Voltage       |     |     | 0.4  | v    | IO = 1.6 mA  |
| VIH    | Input High voltage       | 2.0 |     | A    | v    |              |
| VIL    | Input Low Voltage        |     |     | 0.8  | v    |              |
| IIL    | Input Leakage Current    |     |     | 10   | μΑ   | VIN = VCC    |
| IOL    | Output Leakage Current   |     |     | 10   | μA   | VOUT = VCC   |
| RPU    | Internal Pull-up         | 100 |     | 1700 | μA   | VIN = 0 V    |
| ICC    | Operating Supply Current |     | 75  | 150  | mA   |              |
| PD     | Power Dissipation        |     | 780 |      | mW   |              |



## **APPLICATION INFORMATION**

## VL1772-02: AN IMPROVED VERSION OF THE 1770-00

The 177X family of flexible disk controllers has attracted a great deal of interest from system designers. Allowing compactness and superior performance, this family of advanced ICs has proven to be a success in the marketplace. The original 1770-00 won much approval with its 28-pin package. Its digital data separator allowed consistent operation over temperature, but more was required. The error rate of this data recovery circuit was too high, and a reliable data separator with lower error rates was seen as an important need for computer systems of all types. In addition, a small change of step rate selections could ensure faster throughput, while maintaining compatibility with existing designs.

Thus began the design of a new concept in flexible disk controllers. An important need was to maintain compatibility with existing designs using the 1770-00, while extending the capabilities of the 177X family to include higherperformance drives. These criteria have been satisfied with the VL1772-02.

## IMPROVING THE DATA SEPARATOR

The improvement of the data separator, or data recovery circuit, as it is called, is an important enhancement to the



## TABLE 9. STEP RATE SELECTION: 1770-00 AND VL1772-02

| Step Rate Select Bits |     | Step Rate (ms) |           |  |
|-----------------------|-----|----------------|-----------|--|
| r1                    | rO  | 1770-00        | VL1772-02 |  |
| 0                     | 0   | 6              | 6         |  |
| 0                     | 1   | 12             | 12        |  |
| 1                     | . 0 | 20             | 2         |  |
| 1                     | 1   | 30             | 3         |  |

reliability of the VL1772-02. The operation of this part of the circuit, although critical to system reliability, is simple to understand. Figure 10 shows a train of read data pulses coming from a floppy drive. The clock and data pulses are both in this signal, combined in a simple encoding format. In each bit cell, the data separator chooses a time period within which pulses are recognized as data pulses. The better the resolution for defining this window for the data pulses, the greater the jitter in the signal can be before ones and zeros are incorrectly recognized. This incorrect recognition, and the resultant soft errors, are the basic limiting factor in floopy drive error rates. The VL1772-02, with a wider data window, has a lower chance of incorrect recognition, resulting in lower error rates. This effect will be particularly evident as the user's media degrades with use and jitter increases. This increased reliability of the VL1772-02 can result in fewer returns and greater user satisfaction.

## STEP RATES

With a different selection of step rates than the 1770-00 (see table 9), the VL1772-02 allows the use of drives with minimum settle times up to 12 ms. At the same time, performance is enhanced to take advantage of floppy drives that require only 2 or 3 ms of delay. If a design is currently using head settle times of 6 or 12 ms (as most are), no modifications are required to use the VL1772-02 in the 1770-00 socket. If the current choice of r1 and r0 calls for 20 or 30 ms of delay, use of the VL1772-02 requires:

— the selection of drives that have head settle time under 12 ms, and modified software to allow correct r1, r0 choice, or

- implementation of head settle time in hardware, with an external interrupt.

Fortunately, almost all modern flexible disk drives have head settle times well under 12 ms, and current 1770 applications have taken this into account, using 6 or 12 ms as the head settle time. Where this change is required, it will mean less waiting for the drives to finish each seek. This will certainly produce higher user satisfaction with the system, as well as appreciably higher performance against most benchmarks.

## VL2793 • VL2797



## FLOPPY DISK FORMATTER/CONTROLLER FAMILY

#### FEATURES

- ON-CHIP PLL DATA SEPARATOR
- ON-CHIP WRITE PRECOMPENSATION LOGIC
- SINGLE + 5V SUPPLY
- ACCOMMODATES SINGLE AND DOUBLE DENSITY FORMATS IBM 3740 (FM)

IBM 34 (MFM)

- AUTOMATIC SEEK WITH VERIFY
- MULTIPLE SECTOR READ/WRITE
- TTL COMPATIBLE
- PROGRAMMABLE CONTROL SELECTABLE TRACK-TO-TRACK ACCESS HEAD LOAD TIMING
- SOFTWARE COMPATIBLE WITH THE FD179X SERIES
- SOFT SECTOR FORMAT COMPATIBILITY

#### DESCRIPTION

The VL279X are N-Channel Silicon Gate MOS LSI devices which perform the functions of a Floppy Disk Formatter/Controller in a single chip implementation. The VL279X, which can be considered the end result of both the FD1771 and FD179X designs, is IBM 3740 compatible in single density mode (FM) and System 34 compatible in Double Density Mode (MFM). The VL279X contains all the features of its predecessor the FD179X plus a high performance Phase-Lock-Loop Data Separator as well as Write Precompensation Logic. In Double Density mode, Write Precompensation is automatically engaged to a value programmed via an external potentiometer. In order to maintain compatibility, the FD1771, FD179X and VL279X designs were made as close as possible with the computer interface, instruction set, and I/O registers being identical. Also, head load control is identical. In each case, the actual pin assignments vary by only a few pins from any one to another.

The processor interface consists of an 8-bit bi-directional bus for data, status, and control word transfers. The VL279X is set up to operate on a multiplexed bus with other bus-oriented devices.

The VL279X is TTL compatible on all inputs and outputs. The outputs will drive one TTL load or three LS loads. The 2793 is identical to the 2791 except the DAL lines are TRUE for systems that utilize true data busses.

The 2797 has a side select output for controlling doublesided drives.

## **PIN DIAGRAM**



### **ORDER INFORMATION**

| Part<br>Number | Format  | Package     |  |
|----------------|---------|-------------|--|
| VL2793-PC      | Single- | Plastic DIP |  |
| VL2793-CC      | Sided   | Ceramic DIP |  |
| VL2797-PC      | Double- | Plastic DIP |  |
| VL2797-CC      | Sided   | Ceramic DIP |  |

Note:

Operating temperature range: 0°C to +70°C.



## PIN DESCRIPTION

| PIN NUMBER     | PIN NAME              | SYMBOL                                                                                                                                                                                                                                                                                                                                                | FUNCTION                                                                                                                                                                                                                           |
|----------------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1              | ENABLE PRECOMP        | ENP                                                                                                                                                                                                                                                                                                                                                   | A Logic high on this input enables write precompen-<br>sation to be performed on double density Write Data<br>output only.                                                                                                         |
| 19             | MASTER RESET          | MR                                                                                                                                                                                                                                                                                                                                                    | A logic low (50 microseconds min.) on this input resets the device and loads HEX 03 into the com-                                                                                                                                  |
|                | -                     |                                                                                                                                                                                                                                                                                                                                                       | mand register. The Not Ready (Status Bit 7) is reset<br>during MR ACTIVE. When MR is brought to a logic                                                                                                                            |
|                |                       | 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 -<br>1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 -<br>1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - | high a RESTORE Command is executed, regardless<br>of the state of the Ready signal from the drive. Also,<br>HEX 01 is loaded into sector register.                                                                                 |
| 20             | POWER SUPPLIES        | V <sub>SS</sub>                                                                                                                                                                                                                                                                                                                                       | Ground                                                                                                                                                                                                                             |
| 21             |                       | Vcc                                                                                                                                                                                                                                                                                                                                                   | $+5V \pm 5\%$                                                                                                                                                                                                                      |
| COMPUTER INTE  | RFACE:                |                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                    |
| 2              | WRITE ENABLE          | WE                                                                                                                                                                                                                                                                                                                                                    | A logic low on this input gates data on the DAL into the selected register when CS is low.                                                                                                                                         |
| 3              | CHIP SELECT           | ĊŚ                                                                                                                                                                                                                                                                                                                                                    | A logic low on this input selects the chip and enables computer communication with the device.                                                                                                                                     |
| 4              | READ ENABLE           | RE                                                                                                                                                                                                                                                                                                                                                    | A logic low on this input controls the placement of data from a selected register on the DAL when $\overline{\text{CS}}$ is low.                                                                                                   |
| 5, 6           | REGISTER SELECT LINES | A0, A1                                                                                                                                                                                                                                                                                                                                                | These inputs select the register to receive/transfer data on the DAL lines under $\overline{\text{RE}}$ and $\overline{\text{WE}}$ control:                                                                                        |
|                |                       |                                                                                                                                                                                                                                                                                                                                                       | CS A1 A0 RE WE                                                                                                                                                                                                                     |
|                |                       |                                                                                                                                                                                                                                                                                                                                                       | 0 0 0 Status Reg Command Reg<br>0 0 1 Track Reg Track Reg<br>0 1 0 Sector Reg Sector Reg<br>0 1 1 Data Reg Data Reg                                                                                                                |
| 7-14           | DATA ACCESS LINES     | DAL0-DAL7                                                                                                                                                                                                                                                                                                                                             | Eight bit bi-directional bus used for transfer of com-<br>mands, status, and data. These lines are inverted<br>(active low) on VL279X.                                                                                             |
| 24             | CLOCK                 | CLK                                                                                                                                                                                                                                                                                                                                                   | This input requires a free-running 50% duty cycle square wave clock for internal timing reference, 2 MHz $\pm$ 1% for 8" drives, 1 MHz $\pm$ 1% for mini-floppies.                                                                 |
| 38             | DATA REQUEST          | DRQ                                                                                                                                                                                                                                                                                                                                                   | This output indicates that the Data Register contains<br>assembled data in Read operations, or the DR is<br>empty in Write operations. This signal is reset when<br>serviced by the computer through reading or loading<br>the DR. |
| 39             | INTERRUPT REQUEST     | INTRQ                                                                                                                                                                                                                                                                                                                                                 | This output is set at the completion of any command<br>and is reset when the Status register is read or the                                                                                                                        |
| FLOPPY DISK IN | TERFACE:              |                                                                                                                                                                                                                                                                                                                                                       | Command register is written to.                                                                                                                                                                                                    |
| 15             | STEP                  | STEP                                                                                                                                                                                                                                                                                                                                                  | The step output contains a pulse for each step.                                                                                                                                                                                    |
| 16             | DIRECTION             | DIRC                                                                                                                                                                                                                                                                                                                                                  | Direction Output is active high when stepping in, active low when stepping out.                                                                                                                                                    |
| 17             | 51/4," 8" SELECT      | 5/8                                                                                                                                                                                                                                                                                                                                                   | This input selects the internal VCO frequency for use with $51/4$ " drives or 8" drives.                                                                                                                                           |
| 18             | READ PULSE WIDTH      | RPW                                                                                                                                                                                                                                                                                                                                                   | An external potentiometer tied to this input controls the phase comparator within the data separator.                                                                                                                              |
| 22             | TEST                  | TEST                                                                                                                                                                                                                                                                                                                                                  | A logic low on this input allows adjustment of exter-<br>nal resistors by enabling internal signals to appear on<br>selected pins.                                                                                                 |



## PIN DESCRIPTION (Continued)

| PIN NUMBER | PIN NAME                         | SYMBOL   | FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|----------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23         | PUMP                             | PUMP     | High-Impedance output signal which is forced high<br>or low to increase/decrease the VCO frequency.                                                                                                                                                                                                                                                                                                                                                                  |
| 25         | ENABLE MINI-FLOPPY<br>(2793)     | ENMF     | A logic low on this input enables an internal $\div 2$ of<br>the Master Clock. This allows both 5 <sup>1</sup> /4" and 8" drive<br>operation with a single 2 MHz clock. For a 1 MHz<br>clock on Pin 24, this line must be left open or tied to a<br>Logic 1.                                                                                                                                                                                                         |
| 25         | SIDE SELECT OUTPUT<br>(2797)     | SSO      | The logic level of the Side Select Output is directly controlled by the 'S' flag in Type II or III commands. When $U = 1$ , SSO is set to a logic 1. When $U = 0$ , SSO is set to a logic 0. The SSO is compared with the side information in the Sector I.D. Field. If they do not compare Status Bit 4 (RNF) is set. The Side Select Output is only updated at the beginning of a Type II or III command. It is forced to a logic 0 upon a MASTER RESET condition. |
| 26         | VOLTAGE-CONTROLLED<br>OSCILLATOR | VCO      | An external capacitor tied to this pin adjusts the VCO<br>center frequency.                                                                                                                                                                                                                                                                                                                                                                                          |
| 27         | RAW READ                         | RAW READ | The data input signal directly from the drive. This<br>input shall be a negative pulse for each recorded flux<br>transition.                                                                                                                                                                                                                                                                                                                                         |
| 28         | HEAD LOAD                        | HLD      | The HLD output controls the loading of the Read-<br>Write head against the media.                                                                                                                                                                                                                                                                                                                                                                                    |
| 29         | TRACK GREATER<br>THAN 43         | TG43     | This output informs the drive that the Read/Write<br>head is positioned between tracks 44-76. This output<br>is valid only during Read and Write Commands.                                                                                                                                                                                                                                                                                                           |
| 30         | WRITE GATE                       | WG       | This output is made valid before writing is to be performed on the diskette.                                                                                                                                                                                                                                                                                                                                                                                         |
| 31         | WRITE DATA                       | WD       | MFM or FM output pulse per flux transition. WD<br>contains the unique Address marks as well as data<br>and clock in both FM and MFM formats.                                                                                                                                                                                                                                                                                                                         |
| 32         | READY                            | READY    | This input indicates disk readiness and is sampled<br>for a logic high before Read or Write commands are<br>performed. If Ready is low the Read or Write<br>operation is not performed and an interrupt is<br>generated. Type I operations are performed regard-<br>less of the state of Ready. The Ready input appears in<br>inverted format as Status Register bit 7.                                                                                              |
| 33         | WRITE PRECOMP<br>WIDTH           | WPW      | An external potentiometer tied to this input controls the amount of delay in Write precompensation mode.                                                                                                                                                                                                                                                                                                                                                             |
| 34         | TRACK 00                         | TR00     | This input informs the VL279X that the Read/Write head is positioned over Track 00.                                                                                                                                                                                                                                                                                                                                                                                  |
| 35         | INDEX PULSE                      | ĪP       | This input informs the VL279X when the index hole is encountered on the diskette.                                                                                                                                                                                                                                                                                                                                                                                    |
| 36         | WRITE PROTECT                    | WPRT     | This input is sampled whenever a Write Command is<br>received. A logic low terminates the command and<br>sets the Write Protect Status bit.                                                                                                                                                                                                                                                                                                                          |
| 37         | DOUBLE DENSITY                   | DDEN     | This input pin selects either single or double density operation. When $\overrightarrow{\text{DDEN}} = 0$ , double density is selected. When $\overrightarrow{\text{DDEN}} = 1$ , single density is selected.                                                                                                                                                                                                                                                        |
| 40         | HEAD LOAD TIMING                 | HLT      | When a logic high is found on the HLT input the head<br>is assumed to be engaged. It is typically derived from<br>a 1 shot triggered by HLD.                                                                                                                                                                                                                                                                                                                         |



Figure 1.



#### APPLICATIONS

8" FLOPPY AND 5¼" MINI FLOPPY CONTROLLER SINGLE OR DOUBLE DENSITY CONTROLLER/FORMATTER

The VL279X Family are MOS/LSI devices which perform the functions of a Floppy Disk Controller/Formatter. Software compatible with its predecessor, the FD179X, the device also contains a high performance Phase-Lock-Loop Data Separator as well as Write Precompensation Logic.

When operating in Double Density mode, Write Precompensation may be enabled, its value predetermined by an external potentiometer. An on-chip VCO and phase comparator allows adjustable frequency range for 5<sup>1</sup>/<sub>4</sub> " or 8" Floppy Disk interfacing.

The VL279X is fabricated in NMOS silicon gate technology and available in a 40 pin dual-in-line package.

| FEATURES                               | 2793 | 2797 |
|----------------------------------------|------|------|
| Single Density (FM)                    | x    | Х    |
| Double Density (MFM)                   | x    | х    |
| True Data Bus<br>Inverted Data Bus     | х    | x    |
| Side Select Out<br>Internal CLK Divide | x    | Х    |

#### ORGANIZATION

The Floppy Disk Formatter block diagram is illustrated on page 5. The primary sections include the parallel processor interface and the Floppy Disk interface.

**Data Shift Register** — This 8-bit register assembles serial data from the Read Data input (RAW READ) during Read operations and transfers serial data to the Write Data output during Write operations.

**Data Register** — This 8-bit register is used as a holding register during Disk Read and Write operations in Disk Read operations the assembled data byte is transferred in parallel to the Data Register from the Data Shift Register. In Disk Write operations information is transferred in parallel from the Data Register to the Data Shift Register.

When executing the Seek command the Data Register holds the address of the desired Track position. This register is loaded from the DAL and gated onto the DAL under processor control.

Track Register — This 8-bit register holds the track number of the current Read/Write head position. It is incremented by one every time the head is stepped in (towards track 76) and decremented by one when the head is stepped out (towards track 00). The contents of the register are compared with the recorded track number in the ID field during disk Read, Write and Verify operations. The Track Register can be loaded from or transferred to the DAL. This Register should not be loaded when the device is busy.

Sector Register (SR) — This 8-bit register holds the address of the desired sector position. The contents of the register are compared with the recorded sector number in the ID field during disk Read or Write operations. The Sector Register contents can be loaded from or transferred to the DAL. This register should not be loaded when the device is busy.

**Command Register (CR)** — This 8-bit register holds the command presently being executed. This register should not be loaded when the device is busy unless the new command is a force interrupt. The command register can be loaded from the DAL, but not read onto the DAL.

Status Register (STR) — This 8-bit register holds device Status information. The meaning of the Status bits is a function of the type of command previously executed. This register can be read onto the DAL, but not loaded from the DAL.

**CRC Logic** — This logic is used to check or to generate the 16-bit Cyclic Redundancy Check (CRC). The polynomial is:  $G(x) = x^{16} + x^{12} + x^5 + 1.$ 

The CRC includes all information starting with the address mark and up to the CRC characters. The CRC register is preset to ones prior to data being shifted through the circuit.

Arithmetic/Logic Unit (ALU) — The ALU is a serial comparator, incrementer, and decrementer and is used for register modification and comparisons with the disk recorded ID field.

Timing and Control — All computer and Floppy Disk interface controls are generated through this logic. The internal device timing is generated from an external crystal clock.

AM Detector — The address mark detector detects ID, data and index address marks during read and write operations.

Write Precompensation — enables write precompensation to be performed on the Write Data output.

# VL2793 • VL2797

#### VL279X BLOCK DIAGRAM



**Data Separator** — a high performance Phase-Lock-Loop Data Separator with on-chip VCO and phase comparator allows adjustable frequency range for 5<sup>1</sup>/<sub>4</sub>" or 8" Floppy Disk interfacing.

#### PROCESSOR INTERFACE

The interface to the processor is accomplished through the eight Data Access Lines (DAL) and associated control signals. The DAL are used to transfer Data, Status, and Control words out of, or into the VL279X. The DAL are three state buffers that are enabled as output drivers when Chip Select ( $\overline{CS}$ ) and Read Enable ( $\overline{RE}$ ) are active (low logic state) or act as input receivers when  $\overline{CS}$  and Write Enable ( $\overline{WE}$ ) are active.

When transfer of data with the Floppy Disk Controller is required by the host processor, the device address is decoded and  $\overline{CS}$  is made low. The address bits A1 and A0, combined with the signals  $\overline{RE}$  during a Read operation or  $\overline{WE}$  during a Write operation are interpreted as selecting the following registers:

| A1 · | - A0 | READ (RE)       | WRITE (WE)       |
|------|------|-----------------|------------------|
| 0    | 0    | Status Register | Command Register |
| 0    | 1    | Track Register  | Track Register   |
| 1    | 0    | Sector Register | Sector Register  |
| 1    | 1    | Data Register   | Data Register    |

During Direct Memory Access (DMA) types of data transfers between the Data Register of the VL279X and the processor, the Data Request (DRQ) output is used in Data Transfer control. This signal also appears as status bit 1 during Read and Write operations.

On Disk Read operations the Data Request is activated (set high) when an assembled serial input byte is transferred in parallel to the Data Register. This bit is cleared when the Data Register is read by the processor. If the Data Register is read after one or more characters are lost, by having new data transferred into the register prior to processor readout, the Lost Data bit is set in the Status Register. The Read operation continues until the end of sector is reached.

On Disk Write operations the data Request is activated when the Data Register transfers its contents to the Data Shift Register, and requires a new data byte. It is reset when the Data Register is loaded with new data by the processor. If new data is not loaded at the time the next serial byte is required by the Floppy Disk, a byte of zeroes is written on the diskette and the Lost Data bit is set in the Status Register.

At the completion of every command an INTRQ is generated. INTRQ is reset by either reading the status register or by loading the command register with a new command. In addition, INTRQ is generated if a Force Interrupt command condition is met.



The 279X has two modes of operation according to the state of  $\overline{\text{DDEN}}$  (Pin 37). When  $\overline{\text{DDEN}} = 1$ , Single Density (FM) is selected. When  $\overline{\text{DDEN}} = 0$ , Double Density (MFM) is selected. In either case, the CLK input (Pin 24) is set at 2 MHz for 8" drives or 1 MHz for 51/4" drives.

On the 2791/2793, the ENMF input (Pin 25) can be used for controlling both  $5^{4}$ " and 8" drives with a single 2 MHz clock. When ENMF = 0, an internal + 2 of the CLK is performed. When ENMF = 1, no divide takes place. This allows the use of a 2 MHz clock for both  $5^{1}$ 4" and 8" configurations.

The internal VCO frequency must also be set to the proper value. The  $\overline{5}/8$  input (Pin 17) is used to select data separator operation by internally dividing the Read Clock. When  $\overline{5}/8 = 0$ ,  $5^{1/4}$  " data separation is selected; when 5/8 = 1, 8" drive data separation is selected.

| CLOCK (24) | ENMF (25) | 5/8 (17) | DRIVE  |
|------------|-----------|----------|--------|
| 2 MHz      | 1         | 1        | 8″     |
| 2 MHz      | 0         | 0        | 51⁄4″  |
| 1 MHz      | 1         | 0        | 51/4 " |

#### FUNCTIONAL DESCRIPTION

The VL279X is software compatible with the FD179X series of Floppy Disk Controllers. Commands, status, and data transfers are performed in the same way. Software generated for the 179X can be transferred to a 279X system without modification.

In addition to the 179X, the 279X contains an internal Data Separator and Write precompensation circuit. The TEST (Pin 22) line is used to adjust both data separator and precompensation. When TEST = 0, the WD (Pin 31) line is internally connected to the output of the write precomp one-shot. Adjustment of the WPW (Pin 33) line can then be accomplished. A second one-shot tracks the precomp setting at approximately 3:1 to insure adequate Write Data pulse widths to meet drive specifications.

Similarly, Data separation is also adjusted with  $\overline{\text{TEST}} = 0$ . The TG43 (Pin 29) line is internally connected to the output of the read data one-shot, which is adjusted via the RPW (Pin 18) line. The DIRC (Pin 16) line contains the Read Clock output (5 MHz for 8" drives). The VCO Trimming capacitor (Pin 26) is adjusted for center frequency.

Internal timing signals are used to generate pulses during the adjustment mode so that these adjustments can be made while the device is in-circuit. The TEST line also contains a pull-up resistor, so adjustments can be performed simply by grounding the TEST pin, overriding the pull-up. The TEST pin cannot be used to disable stepping rates during operation as its function is quite different from the 179X.

Other pins on the device also include pull-up resistors and may be left open to satisfy a Logic 1 condition. These are: ENP,  $\overline{5}/8$ ,  $\overline{\text{ENMF}}$ ,  $\overline{\text{WPRT}}$ ,  $\overline{\text{DDEN}}$ , HLT, TEST, and  $\overline{\text{MR}}$ .

#### **GENERAL DISK READ OPERATIONS**

Sector lengths of 128, 256, 512 or 1024 are obtainable in either FM or MFM formats. For FM, DDEN should be placed to logical "1." For MFM formats, DDEN should be

| Sector Length Table*         |                                        |
|------------------------------|----------------------------------------|
| Sector Length<br>Field (hex) | Number of Bytes<br>in Sector (decimal) |
| 00                           | 128                                    |
| 01                           | 256                                    |
| 02                           | 512                                    |
| 03                           | 1024                                   |
|                              |                                        |

\*2793/97 may vary - see command summary.

placed to a logical "0." Sector lengths are determined at format time by the fourth byte in the "ID" field.

The VL279X recognizes tracks and sectors numbered 00-FFX. However, due to programming restrictions, only tracks and sectors 00 thru F4 can be formatted.

#### **GENERAL DISK WRITE OPERATION**

When writing is to take place on the diskette the Write Gate (WG) output is activated, allowing current to flow into the Read/Write head. As a precaution to erroneous writing the first data byte must be loaded into the Data Register in response to a Data Request from the 279X before the Write Gate signal can be activated.

Writing is inhibited when the Write Protect input is a logic low, in which case any Write command is immediately terminated, an interrupt is generated and the Write Protect status bit is set.

For write operations, the 279X provides Write Gate (Pin 30) and Write Data (Pin 31) outputs. Write data consists of a series of pulses set to a width approximately three times greater than the precomp adjustment. Write Data provides the unique address marks in both formats.

#### READY

Whenever a Read or Write command (Type II or III) is received the 279X samples the Ready input. If this input is logic low the command is not executed and an interrupt is generated. All Type I commands are performed regardless of the state of the Ready input. Also, whenever a Type II or III command is received, the TG43 signal output is updated. TG43 may be tied to ENP to enable write precompensation on tracks 44-76.

#### COMMAND DESCRIPTION

The VL279X will accept eleven commands. Command words should only be loaded in the Command Register when the Busy status bit is off (Status bit 0). The one exception is the Force interrupt command. Whenever a command is being executed, the Busy status bit is set. When a command is completed, an interrupt is generated and the Busy status bit is reset. The Status Register indicates whether the completed command encountered an error or was fault free. For ease of discussion, commands are divided into four types. Commands and types are summarized in Table 1.



#### TABLE 1. COMMAND SUMMARY

A. Commands for Model 2793

| A. Commands for Model 2793 |                 |   |      |   |   |    | B. Commands for Model 2797 |      |    |   |   |   |   |    |    |    |    |
|----------------------------|-----------------|---|------|---|---|----|----------------------------|------|----|---|---|---|---|----|----|----|----|
|                            |                 |   | Bits |   |   |    |                            | Bits |    |   |   |   |   |    |    |    |    |
| Туре                       | Command         | 7 | 6    | 5 | 4 | 3  | 2                          | 1    | 0  | 7 | 6 | 5 | 4 | 3  | 2  | 1  | 0  |
| I                          | Restore         | 0 | 0    | 0 | 0 | h  | ٧                          | r1   | ro | 0 | 0 | 0 | 0 | h  | V  | r1 | ro |
| 1                          | Seek            | 0 | 0    | 0 | 1 | h  | V                          | r1   | r0 | 0 | 0 | 0 | 1 | h  | V  | r1 | ro |
| l I                        | Step            | 0 | 0    | 1 | т | h  | V                          | r1   | r0 | 0 | 0 | 1 | Т | h  | V  | r1 | ro |
| 1                          | Step-in         | 0 | 1    | 0 | т | h  | V                          | r1   | ro | 0 | 1 | 0 | Т | h  | V  | r1 | ro |
| 1                          | Step-out        | 0 | 1    | 1 | т | h  | V                          | r1   | ro | 0 | 1 | 1 | Т | h  | V  | r1 | ro |
| !!                         | Read Sector     | 1 | 0    | 0 | m | S  | ε                          | С    | 0  | 1 | 0 | 0 | m | Ĺ  | Ε  | U  | Û  |
| 11                         | Write Sector    | 1 | 0    | 1 | m | S  | Е                          | С    | a0 | 1 | 0 | 1 | m | L  | Е  | U  | a0 |
| III                        | Read Address    | 1 | 1    | 0 | 0 | 0  | Е                          | 0    | 0  | 1 | 1 | 0 | 0 | 0  | Е  | U  | 0  |
| HI                         | Read Track      | 1 | 1    | 1 | 0 | 0  | Е                          | 0    | 0  | 1 | 1 | 1 | 0 | 0  | Е  | U  | 0  |
| 111                        | Write Track     | 1 | 1    | 1 | 1 | 0  | Е                          | 0    | 0  | 1 | 1 | 1 | 1 | 0  | Е  | U  | 0  |
| IV                         | Force Interrupt | 1 | 1    | 0 | 1 | 13 | 12                         | 4    | I0 | 1 | 1 | 0 | 1 | lз | l2 | 11 | 10 |

#### TABLE 2. FLAG SUMMARY

| Command | Bit   |                                                                                                                                                                                                                                                                                                     |                                                                                            |  |  |  |  |  |
|---------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--|--|--|--|--|
| Туре    | No(s) |                                                                                                                                                                                                                                                                                                     | Description                                                                                |  |  |  |  |  |
| I       | 0, 1  | <sup>r</sup> 1 <sup>r</sup> 0 = Stepping Motor Rate<br>See Table 3 for Rate Summary                                                                                                                                                                                                                 |                                                                                            |  |  |  |  |  |
| I       | 2     | V = Track Number Verify Flag $V = 0$ , No verify $V = 1$ , Verify on destination track                                                                                                                                                                                                              |                                                                                            |  |  |  |  |  |
| I       | 3     | h = Head Load Flag                                                                                                                                                                                                                                                                                  | <ul> <li>h = 0, Unload head at beginning</li> <li>h = 1, Load head at beginning</li> </ul> |  |  |  |  |  |
| I       | 4     | T = Track Update Flag                                                                                                                                                                                                                                                                               | T = 0, No update<br>T = 1, Update track register                                           |  |  |  |  |  |
| &       | 0     | a0 = Data Address Mark                                                                                                                                                                                                                                                                              | <sup>a</sup> 0 = 0, FB (DAM)<br><sup>a</sup> 0 = 1, F8 (deleted DAM)                       |  |  |  |  |  |
| II      | 1     | C = Side Compare Flag                                                                                                                                                                                                                                                                               | C = 0, Disable side compare<br>C = 1, Enable side compare                                  |  |  |  |  |  |
| &       | 1     | U = Update SSO                                                                                                                                                                                                                                                                                      | U = 0, Update SSO to 0<br>U = 1, Update SSO to 1                                           |  |  |  |  |  |
| &       | 2     | E = 15 MS Delay                                                                                                                                                                                                                                                                                     | E = 0, No. 15 MS delay<br>E = 1, 15 MS delay (30 MS for 1 MHz)                             |  |  |  |  |  |
| II .    | 3     | S = Side Compare Flag                                                                                                                                                                                                                                                                               | S = 0, Compare for side 0<br>S = 1, Compare for side 1                                     |  |  |  |  |  |
| 11      | 3     | L = Sector Length Flag                                                                                                                                                                                                                                                                              | LSB's Sector Length in ID Field<br>00 01 10 11                                             |  |  |  |  |  |
|         |       |                                                                                                                                                                                                                                                                                                     | L = 0 256 512 1024 128                                                                     |  |  |  |  |  |
|         |       |                                                                                                                                                                                                                                                                                                     | L = 1 128 256 512 1024                                                                     |  |  |  |  |  |
| 11      | 4     | m = Multiple Record Flag                                                                                                                                                                                                                                                                            | m = 0, Single record<br>m = 1, Multiple records                                            |  |  |  |  |  |
| IV      | 0-3   | Ix       = Interrupt Condition Flags         I0       = 1 Not Ready To Ready Transition         I1       = 1 Ready To Not Ready Transition         I2       = 1 Index Pulse         I3       = 1 Immediate Interrupt, Requires A Reset*         I3-IC       = 0 Terminate With No Interrupt (INTRQ) |                                                                                            |  |  |  |  |  |

\*NOTE: See Type IV Command Description for further information.



#### Write Precompensation

When operating in Double Density mode ( $\overline{DDEN} = 0$ ), the 279X has the capability of providing a user-defined precompensation value for Write Data. An external potentiometer (10K) tied to the WPW signal (Pin 33) allows a setting of 100 to 300 ns from nominal.

Setting the Write precomp value is accomplished by forcing the TEST line (Pin 22) to a Logic 0. A stream of pulses can then be seen on the Write Data (Pin 31) line. Adjust the WPW Potentiometer for the desired pulse width. This adjustment may be performed in-circuit since Write Gate (Pin 30) is inactive while TEST = 0.

#### **Data Separation**

The 279X can operate with either an external data separator or its own internal recovery circuits. The condition of the TEST line (Pin 22) in conjunction with  $\overline{\text{MR}}$  (Pin 19) will select internal or external mode.

To program the 279X for external VCO, a  $\overline{\text{MR}}$  pulse must be applied while  $\overline{\text{TEST}} = 0$ . A clock equivalent to eight times the data rate (e.g., 4.0 MHz for 8" Double Density) is applied to the VCO input (Pin 26). The feedback reference voltage is available on the Pump output (Pin 23) for external integration to control the VCO. TEST is returned to a Logic 1 for normal operation. Note: To maintain this mode, TEST must be held low whenever MR is applied.

For internal VCO operation, the  $\overline{\text{TEST}}$  line must be high during the  $\overline{\text{MR}}$  pulse, then set to a Logic 0 for the adjustment procedure.

A 50K Potentiometer tied to the RPW input (Pin 18) is used to set the internal Read Data pulse for proper phasing. With a scope on Pin 29 (TG43), adjust the RPW pulse for 1/8 of the data rate (250 ns for 8" Double Density). An external variable capacitor of 5-60 pf is tied to the VCO input (Pin 26) for adjusting center frequency. With a frequency counter on Pin 16 (DIRC) adjust the trimmer cap to yield the appropriate Data Rate (500 KHz for 8" Double Density). The DDEN line must be low while the 5/8 line is held high or the adjustment times above will be doubled.

After adjustments have been made, the TEST pin is returned to a Logic 1 and the device is ready for operation. Adjustments may be made in-circuit since the DIRC and TG43 lines may toggle without affecting the drive.

The PUMP output (Pin 23) consists of positive and negative pulses, which their duration is equivalent to the phase difference of incoming Data vs. VCO frequency. This signal is internally connected to the VCO input, but a Filter is needed to connect these pulses to a slow moving DC voltage.

The internal phase-detector is unsymmetrical for a random distribution of data pulses by a factor of two, in favor of a PUMP UP condition. Therefore, it is desirable to have a PUMP DOWN twice as responsive to prevent run-away during a lock attempt.

A first order lag-lead filter can be used at the PUMP output (Pin 23). This filter controls the instantaneous response of the VCO to bit-shifted data (jitter) as well as the response to normal frequency shift, i.e., the lock-up time. A balance must be accomplished between the two conditions to inhibit over-responsiveness to jitter and to prevent an extremely wide lock-up response, leading to PUMP runaway. The filter affects these two reactions in mutually opposite directions.

The following Filter Circuit is recommended for 8" FM/MFM:



Since 51/4 " Drives operate at exactly one-half the data rate (250 Kb/sec) the above capacitor should be doubled to .2 or .22 $\mu$ f.

#### TYPE I COMMANDS

The Type I Commands include the Restore, Seek, Step, Step-in, and Step-Out commands. Each of the Type I Commands contains a rate field (r<sub>0</sub> r<sub>1</sub>), which determines the stepping motor rate as defined in Table 3.

A  $2\mu$ s (MFM) or 4  $\mu$ s (FM) pulse is provided as an output to the drive. For every step pulse issued, the drive moves one track location in a direction determined by the direction output. The chip will step the drive in the same direction it last stepped unless the command changes the direction.

The Direction signal is active high when stepping in and low when stepping out. The Direction signal is valid before the first stepping pulse is generated.

The rates (shown in Table 3) can be applied to a Step-Direction Motor through the device interface.

#### TABLE 3. STEPPING RATES

| С  | LK | 2 MHz                        | 1 MHz                        |
|----|----|------------------------------|------------------------------|
| R1 | R0 | $\overline{\text{TEST}} = 1$ | $\overline{\text{TEST}} = 1$ |
| 0  | 0  | 3 ms                         | 6 ms                         |
| 0  | 1  | 6 ms                         | 12 ms                        |
| 1  | 0  | 10 ms                        | 20 ms                        |
| 1  | 1  | 15 ms                        | 30 ms                        |

After the last directional step an additional 15 milliseconds of head settling time takes place if the Verify flag is set in Type I commands. Note that this time doubles to 30 ms for a 1 MHz clock. There is also a 15 ms head settling time if the E flag is set in any Type II or III command.

When a Seek, Step or Restore command is executed an optional verification of Read-Write head position can be performed by setting bit 2(V = 1) in the command word to a logic 1. The verification operation begins at the end of the 15 millisecond settling time after the head is loaded against the media. The track number from the first encountered ID



Field is compared against the contents of the Track Register. If the track numbers compare and the ID Field Cyclic Redundancy Check (CRC) is correct, the verify operation is complete and an INTRQ is generated with no errors. If there is a match but not a valid CRC, the CRC error status bit is set (Status bit 3), and the next encountered ID field is read from the disk for the verification operation.

The VL279X must find an ID field with correct track number and correct CRC within 5 revolutions of the media; otherwise the seek error is set and an INTRQ is generated. If V = 0, no verification is performed.

The Head Load (HLD) output controls the movement of the read/write head against the media. HLD is activated at the beginning of a Type I command if the h flag is set (h = 1), at the end of the Type I command if the verify flag (V = 1), or upon receipt of any Type II or III command. Once HLD is active it remains active until either a Type I command is received with (h = 0 and V = 0); or if the 279X is in an idle state (non-busy) and 15 index pulses have occurred.

Head Load timing (HLT) is an input to the 279X which is used for the head engage time. When HLT = 1, the 279X assumes the head is completely engaged. The head engage time is typically 30 to 100 ms depending on drive. The low to high transition on HLD is typically used to fire a one shot. The output of the one shot is then used for HLT and supplied as an input to the 279X.

#### HEAD LOAD TIMING



When both HLD and HLT are true, the 279X will then read from or write to the media. The "and" of HLD and HLT appears as status Bit 5 in Type I status.

In summary for the Type I commands: if h = 0 and V = 0, HLD is reset. If h = 1 and V = 0, HLD is set at the beginning of the command and HLT is not sampled nor is there an internal 15 ms delay. If h = 0 and V = 1, HLD is set near the end of the command, an internal 15 ms occurs, and the 279X waits for HLT to be true. If h = 1 and V = 1, HLD is set at the beginning of the command. Near the end of the command, after all the steps have been issued, an internal 15 ms delay occurs and the 279X then waits for HLT to occur.

For Type II and III commands with E flag off, HLD is made active and HLT is sampled until true. With E flag on, HLD is made active, an internal 15 ms delay occurs and then HLT is sampled until true.

#### **RESTORE (SEEK TRACK 0)**

Upon receipt of this command the Track 00 (TR00) input is sampled. If TR00 is active low indicating the Read-Write head is positioned over track 0, the Track Register is loaded with zeroes and an interrupt is generated. If TR00 is not

active low, stepping pulses at a rate specified by the <sup>r</sup>1<sup>r</sup>0 field are issued until the TR00 input is activated. At this time the Track Register is loaded with zeroes and an interrupt is generated. If the TR00 input does not go active low after 255 stepping pulses, the 279X terminates operation, interrupts, and sets the Seek error status bit. A verification operation takes place if the V flag is set. The h bit allows the head to be loaded at the start of command. Note that the Restore command is executed when  $\overline{\rm MR}$  goes from an active to an inactive state.

#### SEEK

This command assumes that the Track Register contains the track number of the current position of the Read-Write head and the Data Register contains the desired track number. The VL279X will update the Track register and issue stepping pulses in the appropriate direction until the

#### TYPE I COMMAND FLOW





TYPE I COMMAND FLOW





#### STEP

Upon receipt of this command, the 279X issues one stepping pulse to the disk drive. The stepping motor direction is the same as in the previous step command. After a delay determined by the <sup>r</sup>1<sup>r</sup>0 field, a verification takes place if the V flag is on. If the T flag is on, the Track Register is updated. The h bit allows the head to be loaded at the start of the command. An interrupt is generated at the completion of the command.

#### STEP-IN

Upon receipt of this command, the 279X issues one stepping pulse in the direction towards track 76. If the T flag is on, the Track Register is incremented by one. After a



NOTE 1 MHZ THERE IS A 30MS DELAY

delay determined by the <sup>r</sup>1<sup>r</sup>0 field, a verification takes place if the V flag is on. The h bit allows the head to be loaded at the start of the command. An interrupt is generated at the completion of the command.

#### STEP-OUT

Upon receipt of this command, the 279X issues one stepping pulse in the direction towards track 0. If the T flag is on, the Track Register is decremented by one. After a delay determined by the '1'0 field, a verification takes place if the V flag is on. The h bit allows the head to be loaded at the start of the command. An interrupt is generated at the completion of the command.

#### EXCEPTIONS

On the 2797 device, the SSO output is not affected during Type I commands, and an internal side compare does not take place when the (V) Verify Flag is on.

#### TYPE II COMMANDS

The Type II Commands are the Read Sector and Write Sector commands. Prior to loading the Type II Command into the Command Register, the computer must load the



Sector Register with the desired sector number. Upon receipt of the Type II command, the busy status Bit is set. If the E flag = 1 (this is the normal case) HLD is made active and HLT is sampled after a 15 msec delay. If the E flag is 0, the head is loaded and HLT sampled with no 15 msec delay.

When an ID field is located on the disk, the 279X compares the Track Number on the ID field with the Track Register. If there is not a match, the next encountered ID field is read and a comparison is again made. If there was a match, the Sector Number of the ID field is compared with the Sector Register. If there is not a Sector match, the next encountered ID field is read off the disk and comparisons again made. If the ID field CRC is correct, the data field is then located and will be either written into, or read from

#### TYPE II COMMAND





depending upon the command. The 279X must find an ID field with a Track number, Sector number, side number, and CRC within 5 revolutions of the disk; otherwise, the Record not found status bit is set (Status bit 4) and the command is terminated with an interrupt.

Each of the Type II Commands contains an (m) flag which determines if multiple records (sectors) are to be read or written, depending upon the command. If m = 0, a single sector is read or written and an interrupt is generated at the completion of the command. If m = 1, multiple records are read or written with the sector register internally updated so that an address verification can occur on the next record. The 279X will continue to read or write multiple records and update the sector register in numerical ascending sequence until the sector register exceeds the number of sectors on the track or until the Force Interrupt command is loaded into the Command Register, which terminates the command and generates an interrupt.

For example: If the 279X is instructed to read sector 27 and there are only 26 on the track, the sector register exceeds
# VL2793 • VL2797

## TYPE II COMMAND





the number available. The 279X will search for 5 disk revolutions, interrupt out, reset busy, and set the record not found status bit.

The Type II commands for the 2793 also contain side select compare flags. When C = 0 (Bit 1) no side comparison is made. When C = 1, the LSB of the side number is read off the ID Field of the disk and compared with the contents of the (S) flag (Bit 3). If the S flag compares with the side number recorded in the ID field, the 279X continues with the ID search. If a comparison is not made within 5 index pulses, the interrupt line is made active and the Record-Not-Found status bit is set.

The Type II and III commands for the 2797 contain a side select flag (Bit 1). When U = 0, SSO is updated to 0. Similarly, U = 1 updates SSO to 1. The chip compares the SSO to the ID field. If they do not compare within 5 revolutions the interrupt line is made active and the RNF status bit is set.

The 2797 READ SECTOR and WRITE SECTOR com-

mands include a 'L' flag. The 'L' flag, in conjunction with the sector length byte of the ID Field, allows different byte lengths to be implemented in each sector. For IBM compatibility, the 'L' flag should be set to a one.

#### READ SECTOR

Upon receipt of the Read Sector command, the head is loaded, the Busy status bit set, and when an ID field is encountered that has the correct track number, correct sector number, correct side number, and correct CRC, the data field is presented to the computer. The Data Address Mark of the data field must be found within 30 bytes in single density and 43 bytes in double density of the last ID field CRC byte; if not, the ID field search is repeated.

When the first character or byte of the data field has been shifted through the DSR, it is transferred to the DR, and DRQ is generated. When the next byte is accumulated in the DSR, it is transferred to the DR and another DRQ is generated. If the Computer has not read the previous contents of the DR before a new character is transferred that character is lost and the Lost Data Status bit is set. This sequence continues until the complete data field has been inputted to the computer. If there is a CRC error at the end of the data field, the CRC error status bit is set, and the command is terminated (even if it is a multiple sector command).

At the end of the Read operation, the type of Data Address Mark encountered in the data field is recorded in the Status Register (Bit 5) as shown:

| STATUS<br>BIT 5 |                   |  |
|-----------------|-------------------|--|
| 1               | Deleted Data Mark |  |
| 0               | Data Mark         |  |
|                 |                   |  |

## WRITE SECTOR

Upon receipt of the Write Sector command, the head is loaded (HLD active) and the Busy status bit is set. When an ID field is encountered that has the correct track number, correct sector number, correct side number, and correct CRC, a DRQ is generated. The 279X counts off 11 bytes in single density and 22 bytes in double density from the CRC field and the Write Gate (WG) output is made active if the DRQ is serviced (i.e., the DR has been loaded by the computer). If DRQ has not been serviced, the command is terminated and the Lost Data status bit is set. If the DRQ has been serviced, the WG is made active and six bytes of zeroes in single density and 12 bytes in double density are then written on the disk. At this time the Data Address Mark is then written on the disk as determined by the <sup>a</sup>0 field of the command as shown below:

| ao | Data Address Mark (Bit 0) |
|----|---------------------------|
| 1  | Deleted Data Mark         |
| 0  | Data Mark                 |

The 279X then writes the data field and generates DRQ's to the computer. If the DRQ is not serviced in time for continuous writing the Lost Data Status Bit is set and a byte of zeroes is written on the disk. The command is not terminated. After the last data byte has been written on the disk, the two-byte CRC is computed internally and written on the disk followed by one bye of FE in FM or in MFM. The WG output is then deactivated. For a 2 MHz clock the INTRQ will set 8 to 12  $\mu$ sec after the last CRC byte is written. For partial sector writing, the proper method is to write the data and fill the balance with zeroes. By letting the chip fill the zeroes, errors may be masked by the lost data status and improper CRC Bytes.

## TYPES III COMMANDS READ ADDRESS

Upon receipt of the Read Address command, the head is loaded and the Busy Status Bit is set. The next encountered ID field is then read in from the disk, and the six data bytes of the ID field are assembled and transferred to the DR, and a DRQ is generated for each byte. The six bytes of the ID field are shown below:

| TRACK<br>ADDR | SIDE<br>NUMBER | SECTOR<br>ADDRESS | SECTOR<br>LENGTH | CRC<br>1 | CRC<br>2 |
|---------------|----------------|-------------------|------------------|----------|----------|
| 1             | 2              | 3                 | 4                | 5        | 6        |
| Althoug       | h the CRC      | characters        | are trans        | sferred  | to the   |

## TYPE III COMMAND WRITE TRACK

VL2793 • VL2797



computer, the 279X checks for validity and the CRC error status bit is set if there is a CRC error. The Track Address of the ID field is written into the sector register so that a comparison can be made by the host. At the end of the operation an interrupt is generated and the Busy Status is reset.

#### READ TRACK

Upon receipt of the READ track command, the head is loaded, and the Busy Status bit is set. Reading starts with the leading edge of the first encountered index pulse and continues until the next index pulse. All Gap, Header, and data bytes are assembled and transferred to the data register and DRQ's are generated for each byte. The ac-



## TYPE III COMMAND WRITE TRACK



CONTROL BYTES FOR INITIALIZATION

cumulation of bytes is synchronized to each address mark encountered. An interrupt is generated at the completion of the command.

This command has several characteristics which make it suitable for diagnostic purposes. They are: no CRC checking is performed; gap information is included in the data stream; the internal side compare is not performed; and the address mark detector is on for the duration of the command. Because the A.M. detector is always on, write splices or noise may cause the chip to look for an A.M. If an address mark does not appear on schedule with the Lost Data status flag being set.

The ID A.M., ID field, ID CRC bytes, DAM, Data and Data CRC Bytes for each sector will be correct. The Gap Bytes may be read incorrectly during write-splice time because of synchronization.

### WRITE TRACK FORMATTING THE DISK

(Refer to section on Type III commands for flow diagrams.) Formatting the disk is a relatively simple task when operating programmed I/O or when operating under DMA with a large amount of memory. Data and gap information must be provided at the computer interface. Formatting the disk is accomplished by positioning the R/W head over the desired track number and issuing the Write Track command.

Upon receipt of the Write Track command, the head is loaded and the Busy Status bit is set. Writing starts with the leading edge of the first encountered index pulse and continues until the next index pulse, at which time the interrupt is activated. The Data Request is activated immediately upon receiving the command, but writing will not start until after the first byte has been loaded into the Data Register. If the DR has not been loaded by the time the index pulse is encountered the operation is terminated making the device Not Busy, the Lost Data Status Bit is set, and the interrupt is activated. If a byte is not present in the DR when needed, a byte of zeroes is substituted.

This sequence continues from one index mark to the next index mark. Normally, whatever data pattern appears in the data register is written on the disk with a normal clock pattern. However, if the 279X detects a data pattern of F5 thru FE in the data register, this is interpreted as data address marks with missing clocks or CRC generation.

The CRC generator is initialized when any data byte from F8 to FE is about to be transferred from the DR to the DSR

| DATA PATTERN<br>IN DR (HEX) | VL279X INTERPRETATION<br>IN FM (DDEN = 1) | VL279X INTERPRETATION<br>IN MFM (DDEN = 0)       |
|-----------------------------|-------------------------------------------|--------------------------------------------------|
| 00 thru F4                  | Write 00 thru F4 with CLK = FF            | Write 00 thru F4, in MFM                         |
| F5                          | Not Allowed                               | Write A1* in MFM, Preset CRC                     |
| F6                          | Not Allowed                               | Write C2** in MFM                                |
| F7                          | Generate 2 CRC bytes                      | Generate 2 CRC bytes                             |
| F8 thru FB                  | Write F8 thru FB, Clk = C7, Preset CRC    | Write F8 thru FB, in MFM                         |
| FC                          | Write FC with Clk = D7                    | Write FC in MFM                                  |
| FD                          | Write FD with Clk = FF                    | Write FD in MFM                                  |
| FE                          | Write FE, Clk = C7, Preset CRC            | Write FE in MFM                                  |
| FF                          | Write FF with Clk = FF                    | Write FF in MFM                                  |
| * Missing clock transition  | n between bits 4 and 5                    | ** Missing clock transition between bits 3 and 4 |

VL2793 • VL2797

or by receipt of F5 in MFM. An F7 pattern will generate two CRC characters in FM or MFM. As a consequence, the patterns F5 thru FE must not appear in the gaps, data fields, or ID fields. Also, CRC's must be generated by an F7 pattern.

Disks may be formatted in IBM 3740 or System 34 formats with sector lengths of 128, 256, 512, or 1024 bytes.

#### **TYPE IV COMMANDS**

The Forced Interrupt command is generally used to terminate a multiple sector read or write command or to insure Type I status in the status register. This command can be loaded into the command register at any time. If there is a current command under execution (busy status bit set)

TYPE III COMMAND Read Track/Address

the command will be terminated and the busy status bit reset.

The lower four bits of the command determine the conditional interrupt as follows:

- I0 = Not-Ready to Ready Transition
- 1 = Ready to Not-Ready Transition
- I2 = Every Index Pulse
- 13 = Immediate Interrupt

The conditional interrupt is enabled when the corresponding bit positions of the command  $(^{1}3 \cdot ^{1}0)$  are set to a 1. Then, when the condition for interrupt is met, the INTRQ line will go high signifying that the condition specified has occurred. If  $^{1}3 \cdot ^{1}0$  are all set to zero (HEX D0), no interrupt will occur but any command presently under execution will be immediately terminated. When using the immediate





interrupt condition  $^{1}$ 3 = 1), an interrupt will be immediately generated and the current command terminated. Reading the status or writing to the command register will not automatically clear the interrupt. The HEX D0 is the only command that will enable the immediate interrupt (HEX D8) to clear on a subsequent load command register or read status register operation. Follow a HEX D8 with D0 command.

Wait 8 micro sec (double density) or 16 micro sec (single density) before issuing a new command after issuing a forced interrupt (times double when clock = 1 MHz). Loading a new command sooner than this will nullify the forced interrupt.

Forced interrupt stops any command at the end of an internal micro-instruction and generates INTRQ when the specified condition is met. Forced interrupt will wait until ALU operations in progress are complete (CRC calculations, compares, etc.)

More than one condition may be set at a time. If for example, the READY TO NOT-READY condition  $(^{1}1 = 1)$  and the Every Index Pulse  $(^{1}2 = 1)$  are both set, the resultant command would be HEX "DA." The "OR" function is performed so that either a READY TO NOT-READY or the next Index Pulse will cause an interrupt condition.

### TYPE III COMMAND Read Track/Address



#### STATUS REGISTER

Upon receipt of any command, except the Force Interrupt command, the Busy Status bit is set and the rest of the status bits are updated or cleared for the new command. If the Force Interrupt Command is received when there is a current command under execution, the Busy status bit is reset, and the rest of the status bits are unchanged. If the Force Interrupt command is received when there is not a current command under execution, the Busy Status bit is reset and the rest of the status bits are updated or cleared. In this case, Status reflects the Type I commands.

The user has the option of reading the status register through program control or using the DRQ line with DMA or interrupt methods. When the Data register is read the DRQ bit in the status register and the DRQ line are automatically reset. A write to the Data register also causes both DRQ's to reset.

The busy bit in the status may be monitored with a user program to determine when a command is complete, in lieu of using the INTRQ line. When using the INTRQ, a busy status check is not recommended because a read of the status register to determine the condition of busy will reset the INTRQ line.

The format of the Status Register is shown below:

| (BITS) |    |    |    |    |    |    |    |
|--------|----|----|----|----|----|----|----|
| 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| S7     | S6 | S5 | S4 | S3 | S2 | S1 | S0 |

Status varies according to the type of command executed as shown in Table 4.

Because of internal sync cycles, certain time delays must be observed when operating under programmed I/O. They are: (times double when clock = 1 MHz)

|                          |                                 | Delay Req'd. |      |  |  |
|--------------------------|---------------------------------|--------------|------|--|--|
| Operation                | Next Operation                  | FM           | MFM  |  |  |
| Write to<br>Command Reg. | Read Busy Bit<br>(Status Bit 0) | 12µs         | 6µs  |  |  |
| Write to<br>Command Reg. | Read Status<br>Bits 1-7         | 28µs         | 14µs |  |  |
| Write Any<br>Register    | Read From Diff.<br>Register     | 0            | 0    |  |  |

#### IBM 3740 FORMAT - 128 BYTES/SECTOR

Shown below is the IBM single-density format with 128 bytes/sector. In order to format a diskette, the user must issue the Write Track command, and load the data register with the following values. For every byte to be written, there is one Data Request.



| NUMBER<br>OF BYTES | HEX VALUE OF<br>BYTE WRITTEN | NUMBER<br>OF BYTES | HEX VALUE OF<br>BYTE WRITTEN |
|--------------------|------------------------------|--------------------|------------------------------|
| 40                 | FF (or 00) <sup>3</sup>      | 80                 | 4E                           |
| 6                  | 00                           | 12                 | 00                           |
| 1                  | FC (Index Mark)              | 3                  | F6 (Writes C2)               |
| 1 26               | FF (or 00)                   | 1                  | FC (Index Mark)              |
| 6                  | 00                           | * 50               | 4E <sup>′</sup>              |
| 1                  | FE (ID Address Mark)         | 12                 | 00                           |
| 1                  | Track Number                 | 3                  | F5 (Writes A1)               |
| j 1                | Side Number (00 or 01)       | 1                  | FE (ID Address Mark)         |
| 1                  | Sector Number (1 thru 1A)    | 1 1                | Track Number (0 thru 4C)     |
| 1                  | 00 (Sector Length)           | 1                  | Side Number (0 or 1)         |
| 1                  | F7 (2 CRC's written)         | 1                  | Sector Number (1 thru 1A)    |
| 11                 | FF (or 00)                   | 1                  | 01 (Sector Length)           |
| 6                  | 00                           | 1                  | F7 (2 CRCs written)          |
| 1                  | FB (Data Address Mark)       | 22                 | 4E                           |
| 128                | Data (IBM uses E5)           | 12                 | 00                           |
| 1                  | F7 (2 CRC's written)         | 3                  | F5 (Writes A1)               |
| 27                 | FF (or 00)                   | 1                  | FB (Data Address Mark)       |
| 2472               | FF (or 00)                   | 256                | DATA                         |
|                    |                              | . 1                | E7 (2 CBCs written)          |

54

1. Write bracketed field 26 times

2. Continue writing until 279X interrupts out. Approx. 247 bytes.

3. A '00' option is allowed.

#### **IBM SYSTEM 34 FORMAT-**256 BYTES/SECTOR

Shown below is the IBM dual-density format with 256 bytes/sector. In order for format a diskette the user must issue the Write Track command and load the data register with the following values. For every byte to be written, there is one data request.

## **IBM TRACK FORMAT**

4E 598\*\* 4E \* Write bracketed field 26 times

\*\* Continue writing until 279X interrupts out. Approx. 598 bytes.





### 1. NON-IBM FORMATS

Variations in the IBM formats are possible to a limited extent if the following requirements are met:

- 1) Sector size must be 128, 256, 512 of 1024 bytes.
- 2) Gap 2 cannot be varied from the IBM format.
- 3) 3 bytes of A1 must be used in MFM.

In addition, the Index Address Mark is not required for operation by the 279X. Gap 1, 3, and 4 lengths can be as short as 2 bytes for 279X operation, however PLL lock up time, motor speed variation, write splice area, etc. will add more bytes to each gap to achieve proper operation. It is recommended that the IBM format be used for highest system reliability.

#### **ELECTRICAL CHARACTERISTICS**

Absolute Maximum Ratings Voltage to any input with

respect to  $V_{SS} = +7$  to -0.5VOperating temperature = 0°C to 70°C Storage temperature = -55°C to +125°C

| GAP       | FM                        | MFM                                     |
|-----------|---------------------------|-----------------------------------------|
| Gap I     | 16 bytes FF               | 32 bytes 4E                             |
| GapII     | 11 bytes FF               | 22 bytes 4E                             |
| *         | 6 bytes 00                | 12 bytes 00<br>3 bytes A1               |
| Gap III** | 10 bytes FF<br>4 bytes 00 | 24 bytes 4E<br>8 bytes 00<br>3 bytes A1 |
| Gap IV    | 16 bytes FF               | 16 bytes 4E                             |

\* Byte counts must be exact.

\*\* Byte counts are minimum, except exactly 3 bytes of A1 must be written.

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

| OPERATING CHARACTERISTICS (DC) | ) | $T_A = 0^{\circ}C$ to 70°C, $V_{SS} = 0V$ , $V_{CC} = +2$ | 5V ± .25V |
|--------------------------------|---|-----------------------------------------------------------|-----------|
|--------------------------------|---|-----------------------------------------------------------|-----------|

| SYMBOL | CHARACTERISTIC      | MIN | TYP | MAX  | UNITS | CONDITIONS           |
|--------|---------------------|-----|-----|------|-------|----------------------|
| μL     | Input Leakage       |     |     | 10   | μA    | VIN = VCC            |
| IOL    | Output Leakage      |     |     | 10   | μA    | VOUT = VCC           |
| VIH    | Input High Voltage  | 2.0 |     |      | V     |                      |
| VIL    | Input Low Voltage   |     |     | 0.8  | l v   |                      |
| Vон    | Output High Voltage | 2.4 |     |      | V     | $I_{O} = -100 \mu A$ |
| VOL    | Output Low Voltage  |     |     | 0.45 | V     | $I_{O} = 1.6  mA$    |
| VOHP   | Output High PUMP    | 2.2 |     |      | V     | IOP = -1.0  mA       |
| VOLP   | Output Low PUMP     |     |     | 0.2  | V     | IOP = +1.0  mA       |
| PD     | Power Dissipation   |     |     | .75  | W     | All Outputs Open     |
| Rpu    | Internal Pull-up*   | 100 |     | 1700 | μA    | $V_{IN} = 0V$        |
| ICC .  | Supply Current      | *   | 70  | 150  | mA    | All Outputs Open     |

\* Internal Pull-up resistors on PINS 1, 17, 19, 22, 36, 37 and 40. Also pin 25 on 2793.



## TIMING CHARACTERISTICS $T_A = 0^{\circ}C$ to 70°C, $V_{SS} = 0V$ , $V_{CC} = +5V \pm .25V$

| READ | ENABL | E TI | MING |
|------|-------|------|------|
|------|-------|------|------|

| SYMBOL | CHARACTERISTIC         | MIN | TYP | MAX  | UNITS | CONDITIONS            |
|--------|------------------------|-----|-----|------|-------|-----------------------|
| TSET   | Setup ADDR & CS to RE  | 50  |     |      | nsec  |                       |
| THLD   | Hold ADDR & CS from RE | 10  |     | 1    | nsec  |                       |
| TRE    | RE Pulse Width         | 200 |     |      | nsec  | CL = 50 pf            |
| TDRR   | DRQ Reset from RE      |     | 100 | 200  | nsec  |                       |
| TIRR   | INTRQ Reset from RE    |     | 500 | 3000 | nsec  | See Note              |
| TDACC  | Data Valid from RE     |     | 100 | 200  | nsec  | $C_L = 50  \text{pf}$ |
| TDOH   | Data Hold From RE      | 20  |     | 150  | nsec  | $C_L = 50  \text{pf}$ |

## WRITE ENABLE TIMING

| SYMBOL | CHARACTERISTIC         | MIN | ТҮР | MAX  | UNITS | CONDITIONS |
|--------|------------------------|-----|-----|------|-------|------------|
| TSET   | Setup ADDR & CS to WE  | 50  |     |      | nsec  |            |
| THLD   | Hold ADDR & CS from WE | 10  |     |      | nsec  |            |
| TWE    | WE Pulse Width         | 200 |     |      | nsec  |            |
| TDBB   | DRQ Reset from WE      |     | 100 | 200  | nsec  |            |
| TIRR   | INTRQ Reset from WE    |     | 500 | 3000 | nsec  | See Note   |
| TDS    | Data Setup to WE       | 150 | 1   | 1    | nsec  |            |
| TDH    | Data Hold from WE      | 50  |     |      | nsec  |            |

## **READ ENABLE TIMING**



1 SERVICE (WORST CASE) "FM 275 US "MFM 135 US

DRQ RISING EDGE: INDICATES THAT THE DATA REGISTER HAS ASSEMBLED DATA.

DATA DRO FALLING EDGE: INDICATES THAT THE DATA REGISTER WAS READ INTRO RISING EDGE: OCCURS AT END OF COMMAND INTRO FALLING EDGE: INDICATES THAT THE STATUS REGISTER WAS READ

#### WRITE ENABLE TIMING



DRO RISING EDGE: INDICATES THAT THE DATA REGISTER IS EMPTY DRO FALLING EDGE: INDICATES THAT THE DATA REGISTER IS LOADED INTRO RISING EDGE: INDICATES THAT THE EDD OF A COMMAND INTRO FALLING EDGE: INDICATES THAT THE COMMAND REGISTER IS WITTEN TO



## INPUT DATA TIMING

| SYMBOL          | CHARACTERISTIC       | MIN  | ΤΥΡ  | MAX | UNITS | CONDITIONS |
|-----------------|----------------------|------|------|-----|-------|------------|
| T <sub>PW</sub> | Raw Read Pulse Width | 100  | 200  |     | nsec  |            |
| T <sub>BC</sub> | Raw Read Cycle Time  | 1500 | 2000 |     | nsec  | *          |

## WRITE DATA TIMING: (ALL TIMES DOUBLE WHEN CLK = 1 MHz) (NO WRITE PRECOMPENSATION)

| SYMBOL | CHARACTERISTIC           | MIN | ТҮР | MAX | UNITS | CONDITIONS |
|--------|--------------------------|-----|-----|-----|-------|------------|
| TWP    | Write Data Pulse Width   | 400 | 500 | 600 | nsec  | FM         |
|        |                          | 200 | 250 | 300 | nsec  | MFM        |
| TWG    | Write Gate to Write Data |     | 2   |     | μsec  | FM         |
|        |                          |     | 1   |     | μsec  | MFM        |
| TWF    | Write Gate off from WD   | 1   | 2   |     | µsec  | FM         |
|        |                          |     | 1   |     | μsec  | MFM        |

## **MISCELLANEOUS TIMING:**

| SYMBOL           | CHARACTERISTIC                        | MIN    | TYP | MAX   | UNITS     | CONDITIONS                              |
|------------------|---------------------------------------|--------|-----|-------|-----------|-----------------------------------------|
| tCD1             | Clock Duty (low)                      | 230    | 250 | 20000 | nsec      |                                         |
| tCD <sub>2</sub> | Clock Duty (high)                     | 230    | 250 | 20000 | nsec      | *                                       |
| <sup>t</sup> STP | Step Pulse Output                     | 2 or 4 |     |       | μsec      | See Note                                |
| <sup>t</sup> DIR | Dir Setup to Step                     |        | 12  |       | μsec      | ± CLK ERROR                             |
| tMR              | Master Reset Pulse Width              | 50     |     |       | μsec      | 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - |
| tip              | Index Pulse Width                     | 10     |     |       | μsec      | See Note                                |
| RWP              | Read Window Pulse Width               |        |     |       |           | Input 0-5V                              |
|                  |                                       | 120    |     | 700   | nsec      | MFM                                     |
|                  |                                       | 240    |     | 1400  | nsec      | FM ± 15%                                |
|                  | Precomp Adjust.                       | 100    |     | 300   | nsec      | MFM                                     |
| WPW              | Write Data Pulse Width                |        |     |       |           | Precomp = 100 nsec                      |
|                  |                                       | 200    | 300 | 400   | nsec      | MFM                                     |
| WPW              | Write Data Pulse Width                |        |     |       |           | Precomp = 300 nsec                      |
|                  |                                       | 600    | 900 | 1200  | nsec      | MFM                                     |
| vco              | Free Run Voltage Controlled           | 6.0    |     |       | MHz       | Cext = 0                                |
|                  | Oscillator, Adjustable by ext.        |        | 4.0 |       | MHz       | Cext = 35 pf                            |
|                  | capacitor on Pin 26                   |        |     |       |           |                                         |
|                  | Pump Up $+ 25\%$                      | 5.0    |     |       | MHz       | PU = 2.2V                               |
|                  |                                       |        |     |       |           | Cext = 35 pf                            |
| VCO              | Pump Down – 25%                       |        |     | 3.0   | MHz       | $\overline{PD} = 0.2V$                  |
|                  |                                       |        |     |       |           | Cext = 35  pf                           |
|                  | 5% Change Vcc                         | 3.8    |     | 4.2   | MHz       | Cext = 35  pf                           |
| vco              | $T_{A} = 75^{\circ}C$                 | 3.5    |     |       | MHz       | Cext = 35  pf                           |
| Cext             | Adjustable external capacitor         | 20     | 45  | 100   | pf        | VCO = 40MHz                             |
|                  | · · · · · · · · · · · · · · · · · · · |        |     |       |           | nom                                     |
| RCLK             | Derived read clock                    |        |     |       |           | VCO = 4.0MHz                            |
|                  | = VCO ÷ 8, 16, 32                     |        |     |       |           |                                         |
|                  |                                       |        | 500 |       | KHz       | $\overline{DDEN} = 0$                   |
|                  |                                       |        |     |       |           | $\bar{5}/8 = 1$                         |
|                  |                                       |        | 250 |       | KHz       | $\overline{DDEN} = 0$                   |
|                  |                                       |        |     |       |           | $\bar{5}/8 = 0$                         |
|                  |                                       |        | 250 |       | KHz       | $\overline{\text{DDEN}} = 1$            |
|                  |                                       |        |     | 1. A. |           | $\overline{5}/8 = 1$                    |
|                  |                                       |        | 125 |       | KHz       | $\overline{\text{DDEN}} = 1$            |
|                  |                                       |        |     |       |           | $\overline{5}/8 = 0$                    |
| PU/DON           | PU/PD time on                         |        |     | 250   | ns        | MFM                                     |
|                  | (pulse width)                         |        | 1   | 500   | ns        | FM                                      |
| fLOCK*           | Data Separator Capture Range          | 237.5  | 250 | 262.5 | kbits/sec | $\overline{5}/8 = 0$                    |

\*The fLOCK specification is guaranteed from 10°C to 40°C.



## **MISCELLANEOUS TIMING**



#### WRITE DATA TIMING



#### READ DATA TIMING



#### NOTES:

- 1. Times double when clock = 1 MHz.
- 2. Output timing readings are at  $V_{OL} = 0.8v$  and  $V_{OH} =$ 2.0v.

#### ALL TYPE I READ READ READ WRITE WRITE BIT COMMANDS ADDRESS SECTOR TRACK SECTOR TRACK **S**7 NOT READY NOT READY NOT READY NOT READY NOT READY NOT READY S6 WRITE 0 0 WRITE WRITE 0 PROTECT PROTECT PROTECT **S**5 HEAD LOADED 0 RECORD TYPE 0 0 0 S4 SEEK ERROR RNF RNF RNF 0 0 S3 CRC ERROR CRC ERROR CRC ERROR 0 CRC ERROR 0 S2 LOST DATA LOST DATA LOST DATA TRACK 0 LOST DATA LOST DATA **S**1 INDEX PULSE DRQ DRQ DRQ DRQ DRQ BUSY S0 BUSY BUSY BUSY BUSY BUSY

### STATUS FOR TYPE I COMMANDS

| MEANING                                                                                                                                                                               |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| This bit when set indicates the drive is not ready. When reset it indicates that the drive is ready.<br>This bit is an inverted copy of the Ready input and logically 'ored' with MR. |
| When set, indicates Write Protect is activated. This bit is an inverted copy of WRPT input.                                                                                           |
| When set, it indicates the head is loaded and engaged. This bit is a logical "and" of HLD and HLT signals.                                                                            |
| When set, the desired track was not verified. This bit is reset to 0 when updated.                                                                                                    |
| CRC encountered in ID field.                                                                                                                                                          |
| When set, indicates Read/Write head is positioned to Track 0. This bit is an inverted copy of the TROO input.                                                                         |
| When set, indicates index mark detected from drive. This bit is an inverted copy of the IP input.                                                                                     |
| When set command is in progress. When reset no command is in progress.                                                                                                                |
|                                                                                                                                                                                       |

## \*FROM STEP RATE TABLE

**TABLE 4. STATUS REGISTER SUMMARY** 

#### 4-53

VL2793 • VL2797

## STATUS FOR TYPE II AND III COMMANDS

| BIT NAME                     | MEANING                                                                                                                                                                                                                                            |
|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| S7 NOT READY                 | This bit when set indicates the drive is not ready. When reset, it indicates that the drive is ready. This bit is an inverted copy of the Ready input and 'ored' with MR. The Type II and III Commands will not execute unless the drive is ready. |
| S6 WRITE PROTECT             | On Read Record: Not Used. On Read Track: Not Used. On any Write: It indicates a Write Protect.<br>This bit is reset when updated.                                                                                                                  |
| S5 RECORD TYPE               | On Read Record: It indicates the record-type code from data field address mark. 1 = Deleted Data Mark. 0 = Data Mark. On any Write: Forced to a Zero.                                                                                              |
| S4 RECORD NOT<br>FOUND (RNF) | When set, it indicates that the desired track, sector, or side were not found. This bit is reset when updated.                                                                                                                                     |
| S3 CRC ERROR                 | If S4 is set, an error is found in one or more ID fields; otherwise it indicates error in data field. This bit is reset when updated.                                                                                                              |
| S2 LOST DATA                 | When set, it indicates the computer did not respond to DRQ in one byte time. This bit is reset to zero when updated.                                                                                                                               |
| S1 DATA REQUEST              | This bit is a copy of the DRQ output. When set, it indicates the DR is full on a Read Operation or the DR is empty on a Write operation. This bit is reset to zero when updated.                                                                   |
| S0 BUSY                      | When set, command is under execution. When reset, no command is under execution.                                                                                                                                                                   |

#### SUMMARY OF ADJUSTMENT PROCEDURE

## WRITE PRECOMPENSATION

- 1) Set TEST (Pin 22) to a logic high.
- 2) Strobe MR (Pin 19).
- 3) Set TEST (Pin 22) to a logic low.
- 4) Observe pulse width on WD (Pin 31).
- 5) Adjust WPW (Pin 33) for desired pulse width (Precomp Value).
- 6) Set TEST (Pin 22) to a logic high.

## DATA SEPARATOR

- 1) Set TEST (Pin 22) to a logic high.
- 2) Strobe MR (Pin 19). Insure that 5/8, and DDEN are set properly.
- 3) Set TEST (Pin 22) to a logic low.
- 4 Observe Pulse Width on TG43 (Pin 29).
- 5) Adjust RPW (Pin 18) for 1/8 of the read clock (250ns for 8" DD, 500ns for 51/4" DD, etc.).
- 6) Observe Frequency on DIRC (Pin 16).
- 7) Adjust variable capacitor on VCO pin for Data Rate (500 KHz for 8" DD, 250 KHz for 51/4" DD, etc.).
- 8) Set TEST (Pin 22) to a logic high.

NOTE: To maintain internal VCO operation, insure that TEST = 1 whenever a master reset pulse is applied.

## VL4500A



## **DYNAMIC RAM CONTROLLER**

## FEATURES

- Controls operation of 8K/16K/32K/64K dynamic RAMs
- Creates static RAM appearance
- One package contains address multiplexer, refresh control and timing control
- Directly addresses and drives up to 256K bytes of memory without external drivers
- Operates from microprocessor clock
  - No crystals, delay lines, or RC networks
  - Eliminates arbitration delays
- Refresh may be internally or externally initiated

## **PIN DIAGRAM**

| VL | .45 | 00A |
|----|-----|-----|
|    |     |     |

| CLK 🗌 | 1  | 40 | □ v <sub>cc</sub> |
|-------|----|----|-------------------|
| RDY [ | 2  | 39 | REFREQ            |
|       | 3  | 38 | ] тwsт            |
| cs 🗆  | 4  | 37 | FS0               |
| ALE   | 5  | 36 | ] FS1             |
| RAS0  | 6  | 35 | BA7               |
| RAS1  | 7  | 34 |                   |
| ACR [ | 8  | 33 | MA7               |
| ACW [ | 9  | 32 | ] MA6             |
|       | 10 | 31 | ] CA6             |
|       | 11 | 30 | RA6               |
|       | 12 | 29 | RA5               |
| MA0   | 13 | 28 | CA5               |
| MA1   | 14 | 27 | MA5               |
| CA1   | 15 | 26 | RA4               |
| RA1   | 16 | 25 |                   |
| RA2   | 17 | 24 | MA4               |
| CA2   | 18 | 23 | RA3               |
| MA2   | 19 | 22 |                   |
| GND 🗌 | 20 | 21 | _ MA3             |
|       |    |    |                   |

- Ability to synchronize or interleave controller with the microprocessor system (including multiple controllers)
- 3-state outputs allow multiport memory configuration
- Performance ranges of 150 ns/200 ns/250 ns
- Compatible with TI TMS 4500A

#### DESCRIPTION

The VL4500A is a monolithic DRAM system controller designed to provide address multiplexing, timing, control and refresh/access arbitration functions to simplify the interface of dynamic RAMs to microprocessor systems. The controller contains a 16-bit multiplexer that generates the address lines for the memory device from the 16 system address bits and provides the strobe signals required by the memory to decode the address. An 8-bit refresh counter generates the 256-row addresses required to refresh.

A refresh timer is provided that generates the necessary timing to refresh the dynamic memories and assure data retention.

The VL4500A also contains refresh/access arbitration circuitry to resolve conflicts between memory access requests and memory refresh cycles.

## **BLOCK DIAGRAM**



## ORDER INFORMATION

| Time   | Package                                        |
|--------|------------------------------------------------|
| 150 ns | Plastic DIP<br>Ceramic DIP                     |
| 200 ns | Plastic DIP<br>Ceramic DIP                     |
| 250 ns | Plastic DIP<br>Ceramic DIP                     |
|        | Time        150 ns        200 ns        250 ns |

Operating temperature range: 0°C to +70°C.



## **PIN DESCRIPTIONS**

| RA0-RA7    | Input            | Row Address — Used to generate the row address for the multiplexer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CA0-CA7    | Input            | Column Address — Used to generate the column address for the multiplexer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| MA0-MA7    | Output           | Memory Address — 3-state outputs designed to drive the addresses of the Dynamic RAM array.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| ALE        | Input            | Address Latch Enable — Used to latch the 16 address inputs, $\overline{CS}$ and REN1. This also initiates an access cycle if Chip Select is valid. The rising edge (LOW-to-HIGH level) of ALE returns $\overline{RAS}$ to HIGH.                                                                                                                                                                                                                                                                                                                                                                    |
| ĈŜ         | Input            | Chip Select — A LOW on this input enables an access cycle. The trailing edge of ALE latches the Chip Select input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| REN1       | Input            | RAS Enable 1 — Used to select one of two banks <u>of RAM</u> via the $\overline{RAS}0$ and $\overline{RAS}1$ outputs when chip select is present. When LOW, $\overline{RAS}0$ is selected; when HIGH, $\overline{RAS}1$ is selected.                                                                                                                                                                                                                                                                                                                                                               |
| ACR, ACW   | Input            | Access Control, Read; Access Control, Write — A LOW on either of these inputs causes the column address to appear on MA0-MA7 and the Column Address Strobe to pulse active LOW. The rising edge of $\overrightarrow{ACR}$ or $\overrightarrow{ACW}$ terminates the cycle by ending $\overrightarrow{RAS}$ and $\overrightarrow{CAS}$ strobes. When $\overrightarrow{ACR}$ and $\overrightarrow{ACW}$ are both LOW, MA0-MA7, $\overrightarrow{RAS0}$ , $\overrightarrow{RAS1}$ , and $\overrightarrow{CAS}$ go into a high-impedance (floating) state.                                              |
| CLK        | Input            | System Clock — Provides the master timing to generate refresh cycle timings and refresh rate. Refresh rate is determined by the TWST, FS1, FS0 inputs.                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| REFREQ     | Input/<br>Output | Refresh Request — (This input should be driven by an open-collector output.) On input, a LOW-going edge initiates a refresh cycle and will cause the internal refresh timer to be reset on the next falling edge of the CLK. As an output, a LOW-going edge signals an internal refresh request and that the refresh timer will be reset on the next LOW-going edge of CLK. REFREQ will remain LOW until the refresh cycle is in progress and the current refresh address is present on MAO-MA7. (Note: REFREQ contains an internal pull-up resistor with a nominal resistance of 10 k $\Omega$ .) |
| RAS0, RAS1 | Output           | Row Address Strobe — 3-state outputs used to latch the row address into the bank of DRAMs selected by REN1. On refresh both signals are driven.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| CAS        | Output           | Column Address Strobe — 3-state output used to latch the column address into the DRAM array.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| RDY        | Output           | Ready — Totem-pole output used to synchronize memories that are too slow to guarantee microprocessor access time requirements. This output is also used to inhibit access cycles during refresh when in cycle-steal mode.                                                                                                                                                                                                                                                                                                                                                                          |
| TWST       | Input            | Timing/Wait Strap — A HIGH on this input indicates a wait state should be added to each memory cycle. In addition, it is used in conjunction with FS0 and FS1 to determine refresh rate and timing.                                                                                                                                                                                                                                                                                                                                                                                                |
| FS0, FS1   | Inputs           | Frequency Select 0; Frequency Select 1 — Strap inputs used to select Mode and Frequency of operation as shown in Table 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |



## TABLE 1: STRAP CONFIGURATION

| Strap Input Modes |     | Wait<br>States<br>For<br>Memory | Refresh | Minimum<br>Cik Frea | Refresh | Clock<br>Cycles<br>For Each |         |
|-------------------|-----|---------------------------------|---------|---------------------|---------|-----------------------------|---------|
| TWST              | FS1 | FS0                             | Access  | Access Rate         | (MHz)   | Freq (kHz)                  | Refresh |
| L                 | L   | L (1)                           | 0       | External            |         | Refreq.                     | 4       |
| L                 | L   | н                               | 0       | Clk ÷ 31            | 1.984   | 64-95 (2)                   | 3       |
| L                 | н   | L                               | 0       | Clk ÷ 46            | 2.944   | 64-85 (2)                   | 3       |
| L                 | н   | н                               | 0       | Clk ÷ 61            | 3.904   | 64-82 (3)                   | 4       |
| н                 | L   | L                               | 1       | Clk ÷ 46            | 2.944   | 64-85 (2)                   | 3       |
| н                 | L   | н                               | 1       | Clk ÷ 61            | 3.904   | 64-80 (2)                   | 4       |
| н                 | н   | L                               | 1       | Clk ÷ 76            | 4.864   | 64-77 (2)                   | 4       |
| н                 | н   | н                               | 1       | Clk ÷ 91            | 5.824   | 64-88 (4)                   | 4       |

#### Notes:

1. This strap configuration resets the Refresh Timer circuitry.

2. Upper figure in refresh frequency is the frequency produced if the minimum CLK frequency of the next select state is used.

3. Refresh frequency if CLK frequency is 5 MHz.

4. Refresh frequency if CLK frequency is 8 MHz.

## **FUNCTIONAL DESCRIPTION**

VL4500A consists of six basic blocks; address and select latches, refresh rate generator, refresh counter, the multiplexer, the arbiter, and the timing and control block.

## ADDRESS AND SELECT LATCHES

The address and select latches allow the DRAM controller to be used in systems that multiplex address and data on the same lines without external latches. The row address latches are transparent, meaning that while ALE is HIGH, the output at MA0-MA7 follows the inputs RA0-RA7.

## **REFRESH RATE GENERATOR**

The refresh rate generator is a counter that indicates to the arbiter that it is time for a refresh cycle. The counter divides the clock frequency according to the configuration straps as shown in Table 1. The counter is reset when a refresh cycle is requested or when TWST, FS1 and FS0 are LOW. The configuration straps allow the matching of memories to the system access time.

Upon power-up it is necessary to provide a reset signal by driving all three straps to the controller LOW to initialize internal counters. A system's LOW-active, power-on reset (RESET) can be used to accomplish this by connecting it to those straps that are desired HIGH during operation. During this reset period, at least four clock cycles should occur.

## **REFRESH COUNTER**

The refresh counter contains the address of the row to be refreshed. The counter is decremented after each refresh cycle. [A LOW-to-HIGH transition on TWST sets the refresh counter to FF<sub>16</sub> (255<sub>10</sub>).]

## MULTIPLEXER

The multiplexer provides the DRAM array with row, column, and refresh addresses at the proper times. Its inputs are the address latches and the refresh counter. The outputs provide up to 16 multiplexed addresses on eight lines.

## ARBITER

The arbiter provides two operational cycles; access and refresh. The arbiter resolves conflicts between cycle requests and cycles in execution, and schedules the inhibited cycle when used in cyclesteal mode.

### TIMING AND CONTROL BLOCK

The timing and control block executes the operational cycle at the request of the arbiter. It provides the DRAM array with RAS and CAS signals. It provides the CPU with a RDY signal. It controls the multiplexer during all cycles. It resets the refresh rate generator and decrements the refresh counter during refresh cycles.



## ABSOLUTE MAXIMUM RATINGS

| Operating Ambient<br>Temperature Range            | 0°C to +70°C    |
|---------------------------------------------------|-----------------|
| Storage Temperature<br>Range                      | -65°C to +150°C |
| Supply Voltage<br>Range, V <sub>CC</sub> , Note 1 | -1.5 to +7 V    |
| Input Voltage Range (any input), Note 1           | -1.5 to +7 V    |
| Continuous Power<br>Dissipation                   | 1.2 W           |

Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only. Functional operation of this device at these or any other conditions above those listed on the operational sections of this specification is not implied and exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## DC CHARACTERISTICS: $T_A = 0^{\circ}C$ to $+70^{\circ}C$

| Symbol              | Parameter                                |                                                 | Min      | Тур (3) | Max   | Unit | Conditions                                       |
|---------------------|------------------------------------------|-------------------------------------------------|----------|---------|-------|------|--------------------------------------------------|
| VIL (except REFREQ) | Input LOW Vol                            | tage                                            | -1.0 (2) |         | 0.8   | v    |                                                  |
| VIL (REFREQ)        | Input LOW Vol                            | tage                                            | -1.0 (2) |         | 0.8   | V    |                                                  |
| Viн                 | Input HIGH Vo                            | Itage                                           | 2.4      |         | 6.0   | v    |                                                  |
| Vol                 | Output LOW Ve                            | oltage                                          |          |         | 0.4   | v    | $I_{OL} = 4 \text{ mA}$ $V_{CC} = 4.5 \text{ V}$ |
| .,                  | Output HIGH                              | MA0-MA7, RDY                                    | 2.4      |         |       |      | $1_{0}$                                          |
| Vон                 | Voltage                                  | RAS0, RAS1, CAS                                 | 2.7      |         |       | v    | 10H = -1  IIIA   VCC = 4.5  V                    |
|                     |                                          | REFREQ                                          | 2.4      |         |       |      | $I_{OH} = -100 \ \mu A V_{CC} = 4.5 \ V$         |
| Ін                  | Input HIGH<br>Current<br>All pins except | Input HIGH<br>Current<br>All pins except REFREQ |          |         | 10    | μA   | V <sub>I</sub> = 5.5 V                           |
|                     | Input LOW                                | REFREQ                                          |          |         | -1.25 | mA   |                                                  |
| ΠL                  | Current                                  | All others                                      |          |         | -10   | μA   |                                                  |
| loz                 | Output Off-State Current                 |                                                 |          |         | ±50   | μA   | $V_{O} = 0$ to 4.5 V $V_{CC} = 5.5$ V            |
| lcc                 | Operating Sup                            | ply Current                                     |          | 100     | 140   | mA   | $T_{A} = 0^{\circ}C \qquad V_{CC} = 5.5 V$       |

## CAPACITANCE: T<sub>A</sub> = 25°C, f = 1.0 MHz

| Symbol | Parameter          | Min | Тур (3) | Max | Unit | Conditions  |           |
|--------|--------------------|-----|---------|-----|------|-------------|-----------|
| Cı     | Input Capacitance  |     | 5       |     | pF   | $V_I = 0 V$ | f = 1 MHz |
| Co     | Output Capacitance |     | 6       |     | рF   | $V_O = 0 V$ | f = 1 MHz |

Notes:

1. Voltage values are with respect to the ground terminal.

2. The algebraic convention, where the more negative limit is designated as minimum, is used in this data sheet for logic voltage levels only.

3. All typical values are at  $V_{CC}=5$  V,  $T_A=25^{\circ}C$  except where otherwise noted.

|                      |                                                                | VL4500A-15              |     | VL4500           | DA-20 | VL4500                  |     |      |
|----------------------|----------------------------------------------------------------|-------------------------|-----|------------------|-------|-------------------------|-----|------|
| Symbol               | Parameter                                                      | Min                     | Max | Min              | Max   | Min                     | Max | Unit |
| t <sub>C(C)</sub>    | CLK Cycle Time                                                 | 100                     |     | 120              |       | 140                     |     |      |
| tw(CH)               | CLK HIGH Pulse Width                                           | 40                      |     | 40               |       | 40                      |     | 1    |
| t <sub>W(CL)</sub>   | CLK LOW Pulse Width                                            | 40                      |     | 45               |       | 45                      |     |      |
| tt                   | Transition Time, All Inputs                                    |                         | 50  |                  | 50    |                         | 50  | 1    |
| tAEL-OL              | Time Delay, ALE LOW to<br>CLK Starting LOW, Note 1             | 10                      |     | 10               |       | 15                      |     |      |
| t <sub>CL-AEL</sub>  | Time Delay, CLK LOW to<br>ALE Starting LOW, Note 1             | 10                      |     | 10               |       | 15                      |     | Ī    |
| t <sub>CL-AEH</sub>  | Time Delay, CLK LOW to<br>ALE Starting HIGH, Note 2            | 15                      |     | 20               |       | 20                      |     |      |
| t <sub>W(AEH)</sub>  | Pulse Width ALE HIGH                                           | 50                      |     | 60               |       | 60                      |     | ns   |
| t <sub>AV-AEL</sub>  | Time Delay, Address, REN1,<br>CS Valid to ALE LOW              | 5                       |     | 10               |       | 15                      |     |      |
| t <sub>AEL-AX</sub>  | Time Delay, ALE LOW to<br>Address Not Valid                    | 10                      |     | 10               |       | 10                      |     |      |
| t <sub>AEL-ACL</sub> | Time Delay, ALE LOW to<br>ACX LOW, Notes 3, 4, 5, 6            | t <sub>h(RA)</sub> + 30 |     | $t_{h(RA)} + 40$ |       | t <sub>h(RA)</sub> + 50 |     |      |
| t <sub>ACH-CL</sub>  | Time Delay, ACX HIGH to CLK LOW, Notes 3, 7                    | 20                      |     | 20               |       | 20                      |     |      |
| t <sub>ACL-CH</sub>  | Time Delay, ACX LOW to<br>CLK Starting HIGH (to<br>remove RDY) | 30                      |     | 30               |       | 30                      |     |      |
| t <sub>RQL-CL</sub>  | Time Delay, REFREQ LOW<br>to CLK Starting LOW, Note 8          | 20                      |     | 20               |       | 20                      |     | 1    |
| t <sub>W(RQL)</sub>  | Pulse Width, REFREQ LOW                                        | 20                      |     | 20               |       | 20                      |     | 1    |

## AC CHARACTERISTICS: $T_{A}$ = 0° C to +70° C, $V_{CC}$ = 5 V $\pm$ 10%

Notes:

- 1. Coincidence of the trailing edge of CLK and the trailing edge of ALE should be avoided, as the refresh/access occurs on the trailing CLK edge. A trailing edge of CLK should occur during the interval from ACX HIGH to ALE LOW.
- 2. If ALE rises before ACX and a refresh request is present, the falling edge of CLK after t<sub>CL-AEH</sub> will output the refresh address to MA0-MA7 and initiate a refresh cycle.
- 3. These specifications relate to system timing and do not directly reflect device performance.
- 4. On the access grant cycle following refresh, the occurrence of CAS LOW depends on the relative occurrence of ALE LOW to ACX LOW. If ACX occurs prior to or coincident with ALE then CAS is timed from the CLK HIGH transition that causes RAS LOW. If ACX occurs 20 ns or more after ALE then CAS is timed from the CLK LOW transition following the CLK HIGH transition causing RAS LOW.
- 5. For maximum speed access (internal delays on both access and access grant cycles), ACX should occur prior to or coincident with ALE.
- thIRAI is the dynamic memory row address hold time. ACX should follow ALE by tAEL-CEL in systems where the required thIRAI is greater than tREL-MAX minimum.
- 7. Minimum of 20 ns is specified to ensure arbitration will occur on falling CLK edge. t<sub>ACH-CL</sub> also affects precharge time such that the minimum t<sub>ACH-CL</sub> should be equal or greater than: t<sub>W(RH)</sub>-t<sub>W(CL)</sub> + 30 ns (for cycle where ACX HIGH occurs prior to ALE HIGH) where t<sub>W(RH)</sub> is the DRAM RAS precharge time.
- 8. This parameter is necessary only if refresh arbitration is to occur on this falling edge of CLK (in systems where refresh is synchronized to external events).



| AC CHARACTERISTICS: $T_A = 0$ | $0^{\circ}$ C to +70° C, V <sub>CC</sub> = 5 V ± 10% |
|-------------------------------|------------------------------------------------------|
|-------------------------------|------------------------------------------------------|

|                      |                                                                          | VL450 | 00A-15 | VL45 | 00A-20 | VL450 | 00A-25 |      |                          |
|----------------------|--------------------------------------------------------------------------|-------|--------|------|--------|-------|--------|------|--------------------------|
| Symbol               | Parameter                                                                | Min   | Max    | Min  | Max    | Min   | Max    | Unit | Conditions               |
| tael-rel             | Time Delay, ALE LOW to RAS Starting LOW                                  |       | - 35   |      | 40     |       | 50     |      |                          |
| tt (REL)             | RAS Fall Time                                                            |       | 15     |      | 20     |       | 25     |      | $C_{L} = 160 \text{ pF}$ |
| trav-mav             | Time Delay, Row Address Valid to<br>Memory Address Valid                 |       | 45     |      | 50     |       | 60     |      |                          |
| taen-mav             | Time Delay, ALE HIGH to Valid<br>Memory Address                          |       | 65     |      | 75     |       | 90     |      |                          |
| tAEL-RYL             | Time Delay, ALE to RDY Starting LOW<br>(TWST = 1 or Refresh in Progress) |       | 40     |      | 40     |       | 40     |      | CL = 40 pF               |
| tAEL-CEL             | Time Delay, ALE LOW to CAS Starting LOW, Note 9                          | 60    | 150    | 70   | 200    | 80    | 250    |      |                          |
| taen-ren             | Time Delay, ALE HIGH to RAS Starting HIGH                                |       | 30     |      | 30     |       | 40     |      | C <sub>L</sub> = 160 pF  |
| tt (MAV)             | Address Transition Time                                                  |       | 20     |      | 20     |       | 25     |      |                          |
| tACL-MAX             | Row Address Hold from ACX LOW                                            | 15    |        | 20   |        | 25    |        |      |                          |
| tMAV-CEL             | Time Delay, Memory Address Valid to CAS Starting LOW                     | 0     |        | 0    |        | 0     |        |      |                          |
| tt (CEL)             | CAS Fall Time                                                            |       | 15     |      | 20     |       | 25     |      | C <sub>L</sub> = 320 pF  |
| tacl-cel             | Time Delay, ACX LOW to CAS Starting LOW, Note 9                          | 40    | 100    | 45   | 130    | 50    | 165    |      |                          |
| tACH-REH             | Time Delay, ACX to RAS Starting HIGH                                     |       | 30     |      | 40     |       | 50     |      | C <sub>L</sub> = 160 pF  |
| t <sub>t (REH)</sub> | RAS Rise Time                                                            |       | 15     |      | 20     |       | 25     |      |                          |
| tach-ceh             | Time Delay, ACX HIGH to CAS Starting<br>HIGH                             | 5     | 30     | 10   | 40     | 15    | 50     | ns   |                          |
| tt (CEH)             | CAS Rise Time                                                            |       | 30     |      | 35     |       | 45     |      | C <sub>L</sub> = 320 pF  |
| tach-max             | Column Address Hold from ACX HIGH                                        | 10    |        | 15   |        | 15    |        |      | $C_{L} = 160 \text{ pF}$ |
| tcн-вүн              | Time Delay, CLK HIGH to RDY Starting HIGH (After ACX LOW), Note 10       |       | 40     |      | 45     |       | 60     |      |                          |
| tRFL-RFL             | Time Delay, REFREQ External Until<br>Supported by REFREQ Internal        |       | 30     |      | 35     |       | 35     |      | $C_L = 40 \text{ pF}$    |
| tch-rfl              | Time Delay, CLK HIGH Until REFREQ<br>Internal Starting LOW               |       | 30     |      | 35     |       | 45     |      |                          |
| tcl-mav              | Time Delay, CLK LOW Until Refresh<br>Address Valid                       |       | 75     |      | 100    |       | 125    |      |                          |
| tCH-RRL              | Time Delay, CLK HIGH Until Refresh<br>RAS Starting LOW                   | 10    | 50     | 15   | 60     | 20    | 80     |      |                          |
| tmav-RRL             | Time Delay, Refresh Address Valid<br>Until Refresh RAS LOW               | 5     |        | 5    |        | 5     |        |      |                          |
| tCL-RFH              | Time Delay, CLK LOW to REFREQ<br>Starting HIGH (3-cycle Refresh)         |       | 50     |      | 55     |       | 75     |      | C <sub>L</sub> = 160 pF  |
| tch-rfh              | Time Delay, CLK HIGH to REFREQ<br>Starting HIGH (4-cycle Refresh)        |       | 50     |      | 55     |       | 75     |      |                          |
| tCH-RRH              | Time Delay, CLK HIGH to Refresh RAS Starting HIGH                        | 5     | 35     | 10   | 45     | 10    | 60     |      |                          |
| tch-мах              | Time Delay, Refresh Address Hold<br>After CLK HIGH                       | 15    |        | 20   |        | 25    |        |      |                          |

Notes:

9. The falling edge of CAS occurs as soon as both tAEL-CEL and tACL-CEL have elapsed. If ACX goes LOW prior to (tAEL-CEL) - (tACL-CEL) after ALE, the CAS timing is determined by tAEL-CEL. Otherwise, the access time increases, and the falling edge of CAS is measured from the falling edge of ACX instead of ALE (tACL-CEL determines CAS timing).

10. RDY returns HIGH on the rising edge of CLK. If TWST = 0, then on an access grant cycle RDY goes HIGH on the same edge that causes access RAS LOW. If TWST = 1, then RDY goes to the HIGH level on the first rising CLK edge after ACX goes LOW on access cycles and on the next rising edge after the edge that causes access RAS LOW on access grant cycles (assuming ACX LOW).



|                     |                                                             | VL450 | 00A-15 | VL450 | 00A-20 | VL450 | 0A-25 |           |                         |
|---------------------|-------------------------------------------------------------|-------|--------|-------|--------|-------|-------|-----------|-------------------------|
| Symbol              | Parameter                                                   | Min   | Max    | Min   | Max    | Min   | Max   | Unit      | Conditions              |
| tCH-REL             | Time Delay, CLK HIGH Until Access RAS<br>Starting LOW       |       | 60     |       | 70     |       | 95    |           |                         |
| tcl-cel             | Time Delay, CLK LOW to Access CAS<br>Starting LOW, Note 11  |       | 125    |       | 140    |       | 185   |           | C <sub>L</sub> = 160 pF |
| tCL-MAX             | Row Address Hold After CLK LOW                              | 25    |        | 30    |        | 40    |       |           |                         |
| tw(ACL)             | ACX LOW Width, Note 12                                      | 110   |        | 140   |        | 175   |       | 1         |                         |
| tREL-MAX            | Row Address Hold From RAS LOW                               | 25    |        | 30    |        | 35    |       | 1         |                         |
| tt(RYL)             | RDY Fall Time                                               |       | 10     |       | 15     |       | 20    | ns o to c |                         |
| t <sub>t(RYH)</sub> | RDY Rise Time                                               | 1     | 20     |       | 25     |       | 35    |           | CL = 40 pF              |
| tdis                | Output Disable Time (3-state Outputs)                       |       | 100    |       | 125    |       | 165   | 1         |                         |
| taeh-max            | Column Address Hold From ALE HIGH                           | 10    |        | 15    |        | 20    |       |           |                         |
| t <sub>en</sub>     | Output Enable Time (3-state Outputs)                        |       | 75     |       | 80     |       | 105   |           | CL = 160 pF             |
| tCAV-CEL            | Column Address Setup to CAS After Refresh                   | 0     |        | 0     |        | 0     |       |           |                         |
| tCH-CEL             | Time Delay, CLK HIGH to Access<br>CAS Starting LOW, Note 11 |       | 180    |       | 200    |       | 235   |           |                         |
| tACL-CL             | ACX LOW to CLK Starting LOW, Note 13                        | 25    |        | 35    |        | 45    |       | ]         |                         |
| tACL-RYH            | H ACX LOW to RDY Starting HIGH, Note 13                     |       | 40     |       | 50     |       | 60    | 1         | $C_L = 40 \text{ pF}$   |
| tCL-ACL             | CLK LOW to ACX Starting LOW, Note 13                        | 0     |        | 0     |        | 0     |       | 1         |                         |

## AC CHARACTERISTICS: $T_A = 0^{\circ}$ C to +70° C, $V_{CC} = 5$ V ± 10%

Notes:

11. On the access grant cycle following refresh, the occurrence of CAS LOW depends on the relative occurrence of ALE LOW to ACX LOW. If ACX occurs prior to or coincident with ALE then CAS is timed from the CLK HIGH transition that causes RAS LOW. If ACX occurs 20 ns or more after ALE then CAS is timed from the CLK LOW transition following the CLK HIGH transition causing RAS LOW.

12. The specification of tw (ACL) is designed to allow a CAS pulse. This assures normal operation of the device in testing and system operation.

13. For RDY HIGH transition (during normal access) to be timed from the rising edge of CLK, ACX must occur t<sub>CL-ACL</sub> after the falling edge of CLK. For ACX prior to the falling edge of CLK by t<sub>ACL-CL</sub>, the RDY HIGH transition will be t<sub>ACL-RYH</sub>. Note that t<sub>ACL-CL</sub> is a limiting parameter for control of RDY to be dependent on ACX LOW. During the interval for t<sub>ACL-CL</sub> < MINIMUM to t<sub>CL-ACL</sub> > MINIMUM, the control of RDY may vary between the rising clock edge or falling edge of ACX.

## LOAD CIRCUIT



## AC TESTING INPUT, OUTPUT WAVEFORM



AC testing inputs are driven at 3.0 V for a logic "1" and 0.0 V for a logic "0". Timing measurements are made at 2.2 V for a logic "1" and 0.6 V for a logic "0" at the outputs. The inputs are measured at 2.4 V for a logic "1" and 0.8 V for a logic "0".

\*CL INCLUDES JIG CAPACITANCE



TIMING DIAGRAMS





**REFRESH REQUEST TIMING** 





-tCL-CEL

tCH-CEL

TIMING DIAGRAMS (Cont.)

tMAV-RRI -

CAS

## OUTPUT 3-STATE TIMING



\*The voltage levels (on a RAS or CAS pin) used for testing t<sub>DIS</sub> and t<sub>en</sub> are at 10% and 90% of the V<sub>OH</sub>-V<sub>OL</sub> range for that pin. †On the access grant cycle following refresh, the occurrence of CAS LOW depends on the relative occurrence of ALE LOW to ACX LOW. If ACX occurs prior to or coincident with ALE then CAS is timed from the CLK HIGH transition that causes RAS LOW. If ACX occurs 20 ns or more after ALE then CAS is timed from the CLK LOW transition following the CLK HIGH transition causing RAS LOW.



## TIMING DIAGRAMS (Cont.)

TYPICAL ACCESS/REFRESH/ACCESS CYCLE (3-CYCLE, TWST = 0)



## TYPICAL ACCESS/REFRESH/ACCESS CYCLE (4-CYCLE, TWST = 0)





## TIMING DIAGRAMS (Cont.) TYPICAL ACCESS/REFRESH/ACCESS CYCLE (3-CYCLE, TWST = 1)



### TYPICAL ACCESS/REFRESH/ACCESS CYCLE (4-CYCLE, TWST = 1)





## READY (RDY) SIGNAL TIMING (WAIT STATE OPERATION, TWST = 1)



RDY starting HIGH is timed from ACX LOW (t<sub>ACL-RYH</sub>) for the condition ACX going LOW while CLK HIGH.



RDY starting HIGH is timed from CLK HIGH (t<sub>CH-RYH</sub>) for the condition ACX going LOW while CLK LOW.



## **TYPICAL APPLICATIONS**





#### 8085A CPU INTERFACE TO VL4500A CONTROLLER



## VL4502



## DYNAMIC RAM CONTROLLER

## FEATURES

- Inputs are TTL voltage compatible
- Controls operation of 64K and 256K dynamic RAMs
- Creates static RAM appearance
- One package contains address multiplexer, refresh control and timing control
- Directly addresses and drives up to 2 megabytes of memory without external drivers
- Operates from microprocessor clock
  - ---No crystals, delay lines, or RC networks
  - Eliminates arbitration delays
- Refresh may be internally or externally initiated

## **PIN DIAGRAMS**

| VL4502 DIP |  |    |        |  |  |  |  |
|------------|--|----|--------|--|--|--|--|
|            |  | L  |        |  |  |  |  |
|            |  | 48 | ACR    |  |  |  |  |
| CASO 2     |  | 47 | RAS1   |  |  |  |  |
| RA0 3      |  | 46 | RAS0   |  |  |  |  |
| CAO 4      |  | 45 | ALE    |  |  |  |  |
| MAO 5      |  | 44 | CS     |  |  |  |  |
| MA1 6      |  | 43 | REN1   |  |  |  |  |
| CA1 [7     |  | 42 | RDY    |  |  |  |  |
| RA1 8      |  | 41 | CLK    |  |  |  |  |
| RA2 9      |  | 40 | RAS3   |  |  |  |  |
| CA2 10     |  | 39 | RAS2   |  |  |  |  |
| MA2 11     |  | 38 | CASI   |  |  |  |  |
| GND 12     |  | 37 | GND    |  |  |  |  |
| MA3 13     |  | 36 | REN2   |  |  |  |  |
| CA3 14     |  | 35 | vcc    |  |  |  |  |
| RA3 15     |  | 34 | MA8    |  |  |  |  |
| MA4 16     |  | 33 | CA8    |  |  |  |  |
| CA4 [17    |  | 32 | RA8    |  |  |  |  |
| RA4 18     |  | 31 | REFREC |  |  |  |  |
| MA5 19     |  | 30 | TWST   |  |  |  |  |
| CA5 20     |  | 29 | FS0    |  |  |  |  |
| RA5 21     |  | 28 | FS1    |  |  |  |  |
| RA6 22     |  | 27 | RA7    |  |  |  |  |
| CA6 23     |  | 26 | CA7    |  |  |  |  |
| MA6 24     |  | 25 | MA7    |  |  |  |  |

- High performance CMOS technology
- Strap-selected wait state generation for microprocessor/ memory speed matching
- Ability to synchronize or interleave controller with the microprocessor system (including multiple controllers)
- 3-state outputs allow multiport memory configuration
- Performance ranges of 150 ns/200 ns
- Compatible with VLSI VL4500A and TI TMS4500A, THCT4502

## DESCRIPTION

The VL4502 is a monolithic DRAM system controller providing address multiplexing, timing, control and refresh/access arbitration functions to simplify the interface of dynamic RAMs to microprocessor systems.

The controller contains an 18-bit multiplexer that generates the address lines for the memory device from the 18 system address bits and provides the strobe signals required by the memory to decode the address. A 9-bit refresh counter generates up to 512 row addresses required to refresh.

A refresh timer is provided that generates the necessary timing to refresh the dynamic memories and assure data retention.



## **ORDER INFORMATION**

| Part<br>Number | Access<br>Time | Package                            |
|----------------|----------------|------------------------------------|
| VL4502-15PC    |                | Plastic DIP                        |
| VL4502-15CC    | 150 ns         | Ceramic DIP                        |
| VL4502-15QC    |                | Plastic Leaded Chip Carrier (PLCC) |
| VL4502-20PC    |                | Plastic DIP                        |
| VL4502-20CC    | 200 ns         | Ceramic DIP                        |
| VL4502-20QC    |                | Plastic Leaded Chip Carrier (PLCC) |
| Note:          |                |                                    |

Operating temperature range: 0°C to +70°C.



## **BLOCK DIAGRAM**





## **PIN DESCRIPTIONS**

| Pin<br>Name              | Pin<br>Number,<br>Note 1               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------------------------|----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RA0-RA8                  | 3, 8, 9, 15,<br>18, 21, 22,<br>27, 32  | Row Address—These address inputs are used to generate the row address for the multiplexer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| CA0-CA8                  | 4, 7, 10,<br>14, 17, 20,<br>23, 26, 33 | Column Address—These address inputs are used to generate the column address for the multiplexer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| MA0-MA8                  | 5, 6, 11,<br>13, 16, 19,<br>24, 25, 34 | Memory Address—These three-state outputs are designed to drive the addresses of the Dynamic RAM array.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| ALE                      | 45                                     | Address Latch Enable—This input is used to latch the 18 address inputs, $\overline{CS}$ and REN1 and REN2. This also initiates an access cycle if chip select is valid. The rising edge (LOW level to HIGH level) of ALE returns $\overline{RAS}$ to the HIGH level.                                                                                                                                                                                                                                                                                                                  |
| CS                       | 44                                     | Chip Select—A LOW on this input enables an access cycle. The trailing edge of ALE latches the chip select input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| REN1, REN2               | 43, 36                                 | RAS Enable 1 and 2—These inputs are used to select one of four banks of RAM. When REN2 is LOW, the lower banks are enabled via CAS0, RAS0, and RAS1. When REN2 is HIGH, the higher banks are enabled via CAS1, RAS2, and RAS3. REN1 selects RAS0, RAS2 or RAS1, RAS3 when chip select is present.                                                                                                                                                                                                                                                                                     |
| ACR, ACW                 | 48, 1                                  | Access Control, Read; Access Control, Write—A LOW on either of these inputs causes the col-<br>umn addresses to appear on MA0–MA8 and the column address strobe. The rising edge of ACR<br>or ACW terminates the cycle by ending RAS and CAS strobes. When ACR and ACW are both<br>LOW, MA0–MA8, RAS0, RAS1, RAS2, RAS3, CAS0, and CAS1 go into a HIGH impedance<br>(floating) state.                                                                                                                                                                                                 |
| CLK                      | 41                                     | System Clock—This input provides the master timing to generate refresh cycle timings and refresh rate. Refresh rate is determined by the TWST, FS1, FS0 inputs.                                                                                                                                                                                                                                                                                                                                                                                                                       |
| REFREQ                   | 31                                     | Refresh Request—(This input is driven by an open-collector output.) On input, a LOW-going edge initiates a refresh cycle and will cause the internal refresh timer to be reset on the next falling edge of the CLK. As an output, a LOW-going edge signals an internal refresh request and that the refresh timer will be reset on the next LOW-going edge of CLK. REFREQ will remain LOW until the refresh cycle is in progress and the current refresh address is present on MA0–MA8. (Note: REFREQ contains an internal pull-up resistor with a nominal resistance of 10 kilohms.) |
| RASO, RASI<br>RAS2, RAS3 | 46, 47<br>39, 40                       | Row Address Strobe—These three-state outputs are used to latch the row address into the bank of DRAMs selected by REN1 and REN2. On refresh, all RAS signals are active.                                                                                                                                                                                                                                                                                                                                                                                                              |
| CASO, CASI               | 2, 38                                  | Column Address Strobe—these three-state outputs are used to latch the column address into the DRAM array.                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| RDY                      | 42                                     | Ready—This totem-pole output synchronizes memories that are too slow to guarantee microprocessor access time requirements. This output is also used to inhibit access cycles during refresh when in cycle-steal mode.                                                                                                                                                                                                                                                                                                                                                                 |
| TWST                     | 30                                     | Timing/Wait Strap—A HIGH on this input indicates a wait state should be added to each memory cycle. In addition it is used in conjunction with FS0 and FS1 to determine refresh rate and timing.                                                                                                                                                                                                                                                                                                                                                                                      |
| FS0, FS1                 | 29, 28                                 | Frequency Select 0; Frequency Select 1—These are strap inputs to select Mode and Frequency of operation as shown in Table 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| RESET                    | (PLCC<br>only)                         | RESET—Active LOW input to initialize the controller asynchronously. Refresh Address is set to 1FFH, internal refresh requests, synchronizer, and frequency divider are cleared. This input is driven by an open collector driver.                                                                                                                                                                                                                                                                                                                                                     |
|                          |                                        | RESET contains an internal pull-up with a nominal resistance of 100 K $\Omega$ . This allows the pin to be left open, if desired.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

Note:

1. Pin numbers are for dual in-line package only.



## **TABLE 1: STRAP CONFIGURATION**

| Strap I          | nput Mode   | s, Note 1           | Memory                   |                                                |                            |
|------------------|-------------|---------------------|--------------------------|------------------------------------------------|----------------------------|
| тพรт             | FS1         | FSO                 | Access<br>Wait<br>States | Refresh<br>Rate, Note 2                        | Refresh<br>Clock<br>Cycles |
| L<br>L<br>L<br>L | L<br>L<br>H | L(3)<br>H<br>L<br>H | 0<br>0<br>0<br>0         | External<br>External<br>Clk ÷ 61<br>Clk ÷ 91   | 4<br>3<br>3<br>4           |
| H<br>H<br>H<br>H | L<br>L<br>H | L<br>H<br>L<br>H    | 1<br>1<br>1<br>1         | Clk ÷ 61<br>Clk ÷ 91<br>Clk ÷ 106<br>Clk ÷ 121 | 3<br>4<br>4<br>4           |

## **TABLE 2: OUTPUT STROBE SELECTION**

| Control | Input | Selected Output |      |      |      |      |      |  |
|---------|-------|-----------------|------|------|------|------|------|--|
| REN2    | REN1  | RASO            | RAS1 | RAS2 | RAS3 | CASO | CAS1 |  |
| 0       | 0     | X               |      |      |      | Х    |      |  |
| 0       | 1     |                 | х    |      |      | X    |      |  |
| 1       | 0     |                 |      | X    |      |      | Х    |  |
| 1       | 1     |                 |      |      | X    |      | х    |  |

#### Notes:

1. If the strap configuration is changed, the device should be reset in order to insure normal refresh operation.

2. The maximum refresh rate is a function of the applicable maximum clock frequency (see AC Characteristics).

3. This strap configuration resets the refresh timer circuitry.

## FUNCTIONAL DESCRIPTION

VL4502 consists of six basic blocks; address and select latches, refresh rate generator, refresh counter, the multiplexer, the arbiter, and the timing and control block.

## ADDRESS AND SELECT LATCHES

The address and select latches allow the DRAM controller to be used in systems that multiplex address and data on the same lines without external latches. The row address latches are transparent, meaning that while ALE is HIGH, the output at MAO–MA8 follows the inputs RAO–RA8.

## **REFRESH RATE GENERATOR**

The refresh rate generator is a counter that indicates to the arbiter that it is time for a refresh cycle. The counter divides the clock frequency according to the configuration straps as shown in Table 1. The counter is reset when a refresh cycle is requested or when TWST, FS1 and FS0 are LOW. The configuration straps allow the matching of memories to the system access time. Upon Power-Up, a reset may be accomplished by driving all three strap inputs LOW, or by driving RESET LOW. During this reset period, at least four clock cycles should occur. (See RESET, below.)

## **REFRESH COUNTER**

The refresh counter contains the address of the row to be refreshed. The counter is decremented after each refresh cycle. (A LOW-to-HIGH transition on TWST sets the refresh counter to 1FF<sub>16</sub> (511<sub>10</sub>).

## MULTIPLEXER

The multiplexer provides the DRAM array with row, column, and refresh addresses at the proper times. Its inputs are the address latches and the refresh counter. The outputs provide up to 18 multiplexed addresses on nine lines.

## STATIC OPERATION

The VL4502 is designed for static operation. As a result, the user can use a CLK frequency as low as needed, as long as maximum transition times are not exceeded. As the CLK rate is changed, the refresh rate will change accordingly, in keeping with the frequency-divider specifications above.

## ARBITER

The arbiter provides two operational cycles; access and refresh. The arbiter resolves conflicts between cycle requests and cycles in execution, and schedules the inhibited cycle when used in cycle-steal mode.

## TIMING AND CONTROL BLOCK

The timing and control block executes the operational cycle at the request of the arbiter. It provides the DRAM array with RAS and CAS signals. It provides the CPU with a RDY signal. It controls the multiplexer during all cycles. It resets the refresh rate generator and decrements the refresh counter during refresh cycles.

## RESET

The VL4502 is reset by bringing the timing straps TWST, FS1, and FS0 LOW. The refresh address is set to 1FF, internal refresh requests are synchronized, and the frequency divider is cleared. This reset can occur asynchronously with respect to CLK and control signals. In the PLCC package, the VL4502 can be reset with the RESET signal. In either case, at least four clock cycles should occur during the reset period.



## **ABSOLUTE MAXIMUM RATINGS**

| Ambient Temperatu   | ire                  |
|---------------------|----------------------|
| Under Bias          | - 10°C to + 80°C     |
| Storage Temperatu   | re                   |
| Range               | -65°C to +140°C      |
| Supply Voltage      |                      |
| Range, VCC, Note    | 1 - 0.5 to $+ 7.0$ V |
| Input Voltage Rang  | е                    |
| (any input), Note 1 | -0.5 to +7.0 V       |
| Continuous Power    |                      |
| Dissipation         | 1.2 W                |
|                     |                      |

Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only. Functional operation of this device at these or any other

conditions above those indicated on the operational sections of this specification is not implied and exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## DC CHARACTERISTICS: TA = 0°C to +70°C, VCC = 5 V ± 10%

| Symbol              | Parameter                   |               | Min     | Typ(3) | Max    | Unit | Conditions        |             |
|---------------------|-----------------------------|---------------|---------|--------|--------|------|-------------------|-------------|
| VIH                 | Input HIGH Voltage          |               | 2.4     |        |        | v    |                   |             |
| VIL (except REFREQ) | Input LOW Voltage           |               | VSS-0.5 |        | 0.8    | v    |                   |             |
| VIL (REFREQ)        | Input LOW Voltage           |               | VSS-0.5 |        | 1.2    | v    |                   |             |
| VOH                 | Output HIGH Voltage         | MA0-MA8 RDY   | 2.4     |        |        | v    | IOH = -1 mA       | VCC = 4.5 V |
|                     |                             | RASX, CASX    | 2.7     |        |        |      |                   |             |
|                     |                             | REFREQ        | 2.4     |        |        |      | IOH = - 100 μA    | VCC = 4.5 V |
| VOL                 | Output LOW Voltage          |               |         |        | 0.4    | v    | IOL = 4 mA        | VCC = 4.5 V |
| ШН                  | Input HIGH Current          | REFREQ        |         |        | 100    |      | VI = 5.5 V        |             |
|                     |                             | All Others    |         |        | 10     | μΑ   |                   |             |
| IIL                 | Input LOW Current           | REFREQ, RESET |         |        | - 1.25 | mA   | VI = 0 V          |             |
|                     |                             | All others    |         |        | - 10   | μA   |                   |             |
| IOZ                 | Off-state Output Current    |               |         |        | ±50    | μA   | VO = 0 to 4.5 V   | VCC = 5.5 V |
| ICC(4)              | Operating Supply Current DC |               |         |        | 20     | mA   | $TA = 0^{\circ}C$ | VCC = 5.5 V |
| CI                  | Input Capacitance           |               |         | 5      |        | pF   | VI = 0 V          | f = 1 MHz   |
| со                  | Output Capacitance          |               |         | 6      |        | pF   | VO = 0V           | f = 1 MHz   |

#### **GRAPH 1**



#### Notes:

- 1. Voltage values are with respect to the ground terminal.
- The algebraic convention, where the more negative limit is designated as minimum, is used in this data sheet for logic voltage levels only.
  All typical values are at VCC = 5 V, TA = 25°C except where otherwise noted.
- 4. Refer to Graph 1 for AC Power Consumption Guarantee. In testing, all inputs except CLK are held LOW.



## AC CHARACTERISTICS: $TA = 0^{\circ}C to + 70^{\circ}C$ , $VCC = 5 V \pm 10\%$

| Symbol   | Parameter                                                      | VL450       | 2-15 | VL4502-20   |     | 1    |
|----------|----------------------------------------------------------------|-------------|------|-------------|-----|------|
|          |                                                                | Min         | Max  | Min         | Max | Unit |
| tC(C)    | CLK Cycle Time                                                 | 100         | 7    | 100         |     |      |
| tW(CH)   | CLK HIGH Pulse Width                                           | 25          |      | 25          |     |      |
| tW(CL)   | CLK LOW Pulse Width                                            | 35          |      | 35          |     | 1    |
| tt       | Transition Time, All Inputs                                    |             | 30   |             | 30  | 7    |
| tAEL-CL  | Time Delay, ALE LOW to<br>CLK Starting LOW, Note 1             | 10          |      | 10          |     |      |
| tCL-AEL  | Time Delay, CLK LOW to<br>ALE Starting LOW, Note 1             | 10          |      | 10          |     |      |
| tCL-AEH  | Time Delay, CLK LOW to<br>ALE Starting HIGH, Note 1            | 15          |      | 20          |     |      |
| tW(AEH)  | Pulse Width ALE HIGH                                           | 50          |      | 60          |     | ns   |
| tAV-AEL  | Time Delay, Address, REN <sub>1,2</sub><br>CS Valid to ALE LOW | 5           |      | 10          |     |      |
| tAEL-AX  | Time Delay, ALE LOW to<br>Address Not Valid                    | 10          |      | 10          |     |      |
| tAEL-ACL | Time Delay, ALE LOW to<br>ACX LOW, Notes 3, 4, 5, 6            | th(RA) + 30 |      | th(RA) + 40 |     |      |
| tACH-CL  | Time Delay, ACX HIGH to<br>CLK LOW, Notes 3, 7                 | 20          |      | 20          |     |      |
| tACL-CH  | Time Delay, ACX LOW to<br>CLK Starting HIGH (to<br>remove RDY) | 40          |      | 40          |     |      |
| tRQL-CL  | Time Delay, REFREQ LOW<br>to CLK Starting LOW, Note 8          | 35          |      | 35          |     |      |
| tW(RQL)  | Input Pulse Width, REFREQ LOW                                  | 20          |      | 20          |     |      |

#### Notes:

- 1. Coincidence of the trailing edge of CLK and the trailing edge of ALE should be avoided as the refresh/access occurs during the interval from ACX HIGH to ALE LOW.
- 2. If ALE rises before ACX and a refresh request is present, the falling edge of CLK after tCL-AEH will output the refresh address to MA0–MA8 and initiate a refresh cycle.
- 3. These specifications relate to system timing and do not directly reflect device performance.
- 4. On the access grant cycle following refresh, the occurrence of CAS LOW depends on the relative occurrence of ALE LOW to ACX LOW. If ACX occurs prior to or coincident with ALE then CAS is timed from the CLK HIGH transition that causes RAS LOW. If ACX occurs 20 ns or more after ALE then CAS is timed from the CLK LOW transition following the CLK HIGH transition causing RAS LOW.
- 5. For maximum speed access (internal delays on both access and access grant cycles), ACX should occur prior to or coincident with ALE.
- th(RA) is the dynamic memory row address hold time. ACX should follow ALE by tAEL-CEL in systems where the required th(RA) is greater than tREL-MAX minimum.
- 7. Minimum of 20 ns is specified to ensure arbitration will occur on falling CLK edge. tACH-CL also affects precharge time such that the minimum tACH-CL should be equal or greater than: tW(RH) tW(CL) + 30 ns (for cycle where ACX HIGH occurs prior to ALE HIGH) where tW(RH) is the DRAM RAS precharge time.
- 8. This parameter is necessary only if refresh arbitration is to occur on this LOW-going CLK edge (in systems where refresh is synchronized to external events).



#### VI 4502-15 VI 4502-20 Symbol Parameter Min Min Unit Max Max tAEL-REL Time Delay, ALE LOW to RAS Starting LOW 30 40 tt(REL) **BAS** Fall Time 15 20 tRAV-MAV Time Delay, Row Address Valid to Memory 45 50 Address Valid tAEH-MAV Time Delay, ALE HIGH to Valid 55 70 Memory Address tAEL-RYL Time Delay, ALE to RDY Starting LOW (TWST = 1 or Refresh in Progress) 25 25 tAEL-CEL Time Delay, ALE LOW to CAS Starting LOW 60 150 70 200 tAEH-REH Time Delay, ALE HIGH to RAS Starting HIGH 35 35 tt(MAV) Address Transition Time 15 20 tACL-MAX Row Address Hold from ACX LOW 15 20 tMAV-CEL Time Delay, Memory Address Valid to CAS 0 0 Starting LOW CAS Fall Time tt(CEL) 15 20 tACL-CEL Time Delay, ACX LOW to CAS Starting LOW 50 90 65 130 Time Delay, ACX to RAS Starting HIGH 40 tACH-REH 40 tt(REH) **BAS** Rise Time 15 20 Time Delay, ACX HIGH to CAS Starting HIGH tACH-CEH 5 35 10 40 ns CAS Rise Time tt(CEH) 30 35 tACH-MAX Column Address Hold from ACX HIGH 15 20 Time Delay, <u>CLK</u> HIGH to RDY Starting HIGH (After ACX LOW), Note 9 tCH-RYH 35 45 Time Delay, REFREQ External Until Supported by REFREQ Internal tBFL-BFL 25 30 Time Delay, CLK HIGH Until REFREQ tCH-RFL 30 35 Internal Starting LOW Time Delay, CLK LOW Until Refresh tCL-MAV 75 100 Address Valid tCH-BBL Time Delay, CLK HIGH Until Refresh 10 50 15 60 RAS Starting LOW tMAV-BBI Time Delay, Refresh Address Valid 0 0 Until Refresh RAS LOW Time Delay, CLK LOW to REFREQ Starting tCI -BEH 50 55 HIGH (3 Cycle Refresh) tCH-RFH Time Delay, CLK HIGH to REFRED Starting 45 55 HIGH (4 Cycle Refresh) Time Delay, CLK HIGH to Refresh RAS Starting HIGH tCH-RRH 5 40 10 45 tCH-MAX Time Delay, Refresh Address Hold 15 20 After CLK HIGH

### AC CHARACTERISTICS: $TA = 0^{\circ}C$ to $+70^{\circ}C$ , $VCC = 5 V \pm 10\%$

Note:

 RDY returns HIGH on the rising edge of CLK. If TWST = 0, then on an access grant cycle RDY goes HIGH on the same edge that causes access RAS LOW. If TWST = 1, then RDY goes to the HIGH level on the first rising CLK edge after ACX goes LOW on access cycles and on the next rising edge after the edge that causes access RAS LOW on access grant cycles (assuming ACX LOW).



## AC CHARACTERISTICS: $TA = 0^{\circ}C$ to $+70^{\circ}C$ , $VCC = 5 V \pm 10\%$

|          | Parameter                                                  | VL4                   | 502-15 | VL4502-20 |     |      |  |
|----------|------------------------------------------------------------|-----------------------|--------|-----------|-----|------|--|
| Symbol   |                                                            | Min                   | Max    | Min       | Max | Unit |  |
| tCH-REL  | Time Delay, CLK HIGH Until Access RAS<br>Starting LOW      |                       | 60     |           | 70  |      |  |
| tCL-CEL  | Time Delay, CLK LOW to Access CAS<br>Starting LOW, Note 10 |                       | 125    |           | 140 |      |  |
| tCL-MAX  | Row Address Hold After CLK LOW                             | 25                    |        | 30        |     |      |  |
| tW(ACL)  | ACX LOW Width                                              | 95                    |        | 120       |     | _    |  |
| tREL-MAX | Row Address Hold From RAS LOW                              | 25                    |        | 30        |     |      |  |
| tt(RYL)  | RDY Fall Time                                              |                       | 10     |           | 15  | ns   |  |
| tt(RYH)  | RDY Rise Time                                              |                       | 20     |           | 25  |      |  |
| tdis     | Output Disable time (3-State Outputs)                      |                       | 100    |           | 125 |      |  |
| tAEH-MAX | Column Address Hold From ALE HIGH                          | 10                    |        | 15        |     |      |  |
| ten      | Output Enable Time (3-State Outputs)                       |                       | 65     |           | 80  |      |  |
| tCAV-CEL | Column Address Setup to CAS After<br>Refresh               | 0                     |        | 0         |     |      |  |
| tCH-CEL  | Time Delay, CLK HIGH to Access<br>CAS Starting LOW, Note 9 |                       | 140    |           | 180 |      |  |
| t RESET  | Power Up RESET                                             | Four (4) Clock Cycles |        |           |     |      |  |

#### Notes:

10. On the access grant cycle following refresh, the occurrence of CAS LOW depends on the relative occurrence of ALE LOW to ACX LOW. If ACX occurs prior to or coincident with ALE then CAS is timed from the CLK LOW transition that causes RAS LOW. If ACX occurs 20 ns or more after ALE then CAS is timed from the CLK LOW transition following the CLK HIGH transition causing RAS LOW.

## OUTPUT LOAD CONDITIONS: vcc = 5.0 v



## AC TESTING INPUT, OUTPUT WAVEFORM



AC TESTING INPUTS ARE DRIVEN AT 3.0 V FOR A LOGIC "1" AND 0.0 V FOR A LOGIC "0". TIMING MEASUREMENTS ARE MADE AT 2.4 V FOR A LOGIC "1" AND 0.8 V FOR A LOGIC "0" AT THE OUTPUTS.



## TIMING DIAGRAMS

ACCESS CYCLE TIMING



#### **REFRESH REQUEST TIMING**





## TIMING DIAGRAMS (Cont.)

## **OUTPUT 3-STATE TIMING**



#### **REFRESH CYCLE TIMING (3-CYCLE)**



### **REFRESH CYCLE TIMING (4-CYCLE)**



ON THE ACCESS GRANT CYCLE FOLLOWING REFRESH, THE <u>OC</u>CURRENCE <u>OF</u> <u>CAS</u> LOW DEPENDS ON THE RELATIVE OCCURRENCE <u>OF</u> <u>ALE</u> LOW TO <u>ACX</u> LOW. IF <u>ACX</u> OCCURS PRIOR TO OR COINCIDENT WITH <u>ALE</u> THEM<u>CAS</u> IS TIMED FROM THE CLK HIGH <u>TRANSITION</u> THAT CAUSES RAS LOW. IF <u>ACX</u> OCCURS 20 NS OR MORE <u>AFTER</u> <u>ALE</u> THEN <u>CAS</u> IS TIMED FROM THE CLK HIGH TRANSITION CAUSING RAS LOW.



## TIMING DIAGRAMS (Cont.)

TYPICAL ACCESS/REFRESH/ACCESS CYCLE (3-CYCLE, TWST = 0)



## TYPICAL ACCESS/REFRESH/ACCESS CYCLE (4-CYCLE, TWST = 0)




# TIMING DIAGRAMS (Cont.)

TYPICAL ACCESS/REFRESH/ACCESS CYCLE (3-CYCLE, TWST = 1)



TYPICAL ACCESS/REFRESH/ACCESS CYCLE (4-CYCLE, TWST = 1)



4-80



# READY (RDY) SIGNAL TIMING (WAIT STATE OPERATION, TWST = 1)



RDY starting HIGH is timed from CLK HIGH (tCH-RYH)



# PARALLEL INTERFACE/TIMER

# FEATURES

- Low power consuming CMOS Parallel Interface/Timer (VL65C22)
- Low cost HMOS Parallel Interface/Timer (VL6522)
- Two 8-bit bidirectional I/O ports
- Two 16-bit timer/counters
- Serial bidirectional peripheral I/O port
- Enhanced handshake features
- Programmable data direction registers
- TTL-compatible I/O peripheral lines

# **PIN DIAGRAM**

VL6522 VL65C22

| GND | d          | $\neg$ | 40 | Ь | CA1 |
|-----|------------|--------|----|---|-----|
| PA0 |            |        | 39 | Ь | CA2 |
| PA1 |            |        | 38 | Ь | RS0 |
| PA2 |            |        | 37 | Ь | RS1 |
| PA3 | <b>C</b> 5 |        | 36 | Ь | RS2 |
| PA4 | d6         |        | 35 | Ь | RS3 |
| PA5 | d7         |        | 34 | Ь | RES |
| PA6 | ds         |        | 33 | Ь | D0  |
| PA7 | C 9        |        | 32 | Ь | D1  |
| PB0 | d١         | 0      | 31 | Ь | D2  |
| PB1 | dı         | 1      | 30 | Ь | D3  |
| PB2 | dı         | 2      | 29 | Ь | D4  |
| PB3 | d1         | 3      | 28 | Ь | D5  |
| PB4 | dı         | 4      | 27 | Ь | D6  |
| PB5 | d1         | 5      | 26 | Þ | D7  |
| PB6 | d1         | 6      | 25 | Þ | Ø2  |
| PB7 |            | 7      | 24 | Þ | CS1 |
| CB1 |            | 8      | 23 | þ | CS2 |
| CB2 |            | 9      | 22 | þ | R/W |
| vcc |            | 0      | 21 | Ь | IRQ |
|     |            |        |    |   |     |

# DESCRIPTION

The VL6522/VL65C22 are flexible I/O devices for use with the 65XX family of processors. The VL65C22 is a CMOS implementation of the VL65C2 device. Both include functions for programmed control of up to two peripheral devices (ports A and B). Two program-controlled 8-bit bidirectional peripheral I/O ports allow direct interfacing between the microprocessor and selected peripheral devices. Two programmable Data Direction Registers (A and B) allow selection of data direction (input versus output) on an individual line-by-line basis. Also provided are two programmable 16-bit counter/timers with latches. Timer 1 may be operated in a one-shot interrupt mode with interrupts on each count-to-zero, or in a freerunning mode with a series of evenly spaced interrupts. Timer 2 functions both as an interval and pulse counter. Seriai data transfers are provided by a shift register. Application versatility is further increased by various control registers, including an interrupt flag register, an interrupt enable register, and two function control registers.

# **BLOCK DIAGRAM**



# ORDER INFORMATION

| Part<br>Number | Technology | Clock<br>Frequency | Package                     |
|----------------|------------|--------------------|-----------------------------|
| VL6522-01PC    | HMOS       |                    | Plastic DIP                 |
| VL6522-01QC    | CMOS       | 1 MU7              | Plastic DIP                 |
| VL65C22-01PC   | HMOS       | 1 1011 12          | Plastic Leaded Chip Carrier |
| VL65C22-01QC   | CMOS       |                    | Plastic Leaded Chip Carrier |
| VL6522-02PC    | HMOS       |                    | Plastic DIP                 |
| VL6522-02QC    | CMOS       | 0 MU-              | Plastic DIP                 |
| VL65C22-02PC   | HMOS       | 2 101712           | Plastic Leaded Chip Carrier |
| VL65C22-02QC   | CMOS       |                    | Plastic Leaded Chip Carrier |
| VL65C22-03PC   | CMOS       | 9 M⊔7              | Plastic DIP                 |
| VL65C22-03QC   | CMOS       | 3 IVITIZ           | Plastic Leaded Chip Carrier |
| VL65C22-04PC   | CMOS       |                    | Plastic DIP                 |
| VL65C22-04QC   | CMOS       | 4 MHz              | Plastic Leaded Chip Carrier |

Note: Operating temperature range: 0°C to +70°C.

# SIGNAL DESCRIPTIONS

| Signal<br>Name                | Pin<br>Number | Signal<br>Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------------------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RES                           | 34            | The LOW input reset clears all VL65(C)22 internal registers to logic 0 (except T1 and T2 latches and counters and the shift register). This places all peripheral interface lines in the input state, disables the timers, shift register, etc., and disables interrupting from the chip.                                                                                                                                                                                                                                                               |
| Ø2                            | 25            | The input clock is the system Ø2 clock, which triggers all data transfers between the<br>processor bus and the VL65(C)22.                                                                                                                                                                                                                                                                                                                                                                                                                               |
| R∕₩                           | 22            | The direction of the data transfers between the VL65(C)22 and the system processor is controlled by the R/W line in conjunction with the CS1 and CS2 inputs. When R/W is LOW (write operation) and the VL65(C)22 is selected, data is transferred from the processor bus into the selected VL65(C)22 register. When R/W is HIGH (read operation) and the chip is selected, data is transferred from the selected VL65(C)22 register to the CPU.                                                                                                         |
| D0-D7                         | 33-26         | The eight bidirectional data bus lines transfer data between the VL65(C)22 and the system<br>processor bus. During read cycles, the contents of the selected VL65(C)22 register is<br>placed on the data bus lines. During write cycles, these lines are high-impedance inputs<br>and data is transferred from the processor bus into the selected register. When the<br>VL65(C)22 is not selected, the data bus lines are high-impedance.                                                                                                              |
| CS1, <u>CS2</u>               | 24, 23        | The two chip select inputs are normally connected to processor address lines either<br>directly or <u>thro</u> ugh decoding. The selected VL65(C)22 register is accessed when CS1 is<br>HIGH and CS2 is LOW.                                                                                                                                                                                                                                                                                                                                            |
| RS0, <b>RS1, RS2</b> ,<br>RS3 | 38 - 35       | The coding of the four register select inputs selects one of the 16 internal registers of the VL65(C)22, as shown in Table 2.                                                                                                                                                                                                                                                                                                                                                                                                                           |
| TRQ                           | 21            | The interrupt request output goes LOW whenever an internal interrupt flag is set and the<br>corresponding interrupt enable bit is a logic 1. This is an open-drain output, which allows<br>the interrupt request signal to be in a wire-OR logic state with other equivalent signals in<br>the surter.                                                                                                                                                                                                                                                  |
| PAU-PA7                       | 2-9           | Port A consists of eight lines that can be individually programmed to act as inputs or<br>outputs under control of data direction register A. The polarity of output pins is controlled<br>by an output register and input data may be latched into an internal register under control<br>of the CA1 line. All of these modes of operation are controlled by the system processor<br>through the internal control registers. These lines, represent one standard TTL load in the<br>input mode and will drive one standard TTL load in the output mode. |
| PB0 - PB7                     | 10 - 17       | Peripheral data port B is an 8-line, bidirectional bus that is controlled by an output register,<br>input register and data direction register in a manner much the same as data port A. With<br>respect to port B, the output signal on line PB7 may be controlled by Timer 1, while Timer 2<br>may be programmed to count pulses on line PB6. Port B lines are also capable of sourcing<br>3.0 mA at 1.5 Vdc in the output mode. This allows the outputs to directly drive Darlington<br>transistor circuits.                                         |
| CA1, CA2                      | 40, 39        | Control lines CA1 and CA2 serve as interrupt inputs or handshake outputs for peripheral<br>data port A. Each line controls an internal interrupt flag with a corresponding interrupt<br>enable bit. CA1 also controls the latching of input data on port A. CA1 is a high-<br>impedance input, while CA2 represents one standard TTL load in the input mode. In the<br>output mode, CA2 will drive one standard TTL load.                                                                                                                               |
| CB1, CB2                      | 18, 19        | Control lines CB1 and CB2 serve as interrupt inputs or handshake outputs for peripheral data port B. Like port A, these two control lines control an internal interrupt flag with a corresponding interrupt enable bit. These lines also serve as a serial data port under control of the shift register (SR). Each control line represents one standard TTL load in the input mode and can drive one TTL load in the output mode. Note that CB1 and CB2 cannot drive Darlington transistor circuits.                                                   |
| VCC                           | 20            | +5 V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| GND                           | 1             | Ground                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

FIGURE 1. MICROPROCESSOR AND PERIPHERAL INTERFACE



# FUNCTIONAL DESCRIPTION PERIPHERAL DATA PORTS

## (PORT A, PORT B) Each peripheral data port operates in

Each peripheral data port operates in conjunction with a data direction register (DDRA or DDRB). Under program control, the data direction registers specify which lines within the port bus are to be designated as inputs or outputs. A logic 0 in any bit position of the register will cause the corresponding line to serve as an input, while a logic 1 will cause the line to serve as an output.

When a line is programmed as an output, it is controlled by a corresponding bit in the output register (ORA or ORB). A logic 1 in the output register will cause the corresponding output line to go HIGH, while a Logic 0 will cause the line to go LOW. Under program control, data is written into the Output Register bit positions corresponding to the output lines that have been programmed as outputs. Should data be written into bit positions corresponding to lines that have been programmed as inputs, the output lines will be unaffected.

When reading a peripheral data port, the contents of the corresponding Input register (IRA or IRB) are transferred onto the data bus. When the input latching feature is disabled, input register A (IRA) will reflect the logic levels present on the port A bus lines. However, with input latching enabled and the selected active transition on CA1 having occurred, input register A will contain the data present on the port

A bus lines at the time of the transition. In this case, once input register A has been read, it will appear transparent, reflecting the current state of the port A bus lines until the next CA1 latching transition.

Input register B operates similar to input register A except that for those port B bus lines that have been programmed as outputs. When reading input register A, the logic level on the bus line determines whether a logic 1 or 0 is sensed. However, when reading input register B, the logic level stored in output register B (ORB) is the logic level sensed. For this reason, those outputs that have large loading effects may cause the reading of input register A to result in the reading of logic 0 when a 1 was actually programmed, and reading a logic 1 when a 0 was programmed. However, when reading input register B, the logic level read will be correct, regardless of loading on the particular bus line.

For information on formats and operation of the peripheral data port registers, refer to Figures 14, 15, 16, and 17. It should be noted that the input latching modes are controlled by the auxiliary control register.

#### DATA TRANSFER - HANDSHAKE CONTROL

A powerful feature of the VL65(C)22 is its ability to provide absolute control over data transfers between the microprocessor and peripheral devices. This control is accomplished by way of handshake lines. Port A lines (CA1, CA2) handshake data transfers on both read and write operations, while port B lines (CB1, CB2) handshake data on write operations only.

**READ HANDSHAKE CONTROL** 

Read handshaking provides effective control of data transfers from a peripheral device to the microprocessor. To accomplish the read handshake, the peripheral device generates a data ready signal to the VL65(C)22 that indicates valid data is present on the peripheral data port bus. In most cases, this data ready signal will interrupt the microprocessor, which will then read the data and generate a data taken signal. Once the peripheral senses the data taken signal, new data will be placed on the bus. This process continues until the data transfer is complete.

Automatic read handshaking applies to peripheral data port A only. The data ready signal is transmitted by the peripheral device over the CA1 interrupt line, while the data taken signal is generated and transmitted to the peripheral device over the CA2 line. When the data ready signal is received, it sets an internal flag in the interrupt flag register (IFR). This flag may interrupt the microprocessor or it may be polled under program control. As an

option, the data taken signal may be either a pulse or a level. In either case, it is set LOW (logic 0) by the microprocessor and is cleared by the next data ready signal. Refer to Figures 3 and 4 for read handshake timing and operating sequence.

#### WRITE HANDSHAKE CONTROL

The write handshake operation is similar to read handshaking. For write handshaking, however, the VL65(C)22 generates the data ready signal and the peripheral device must generate the data taken return signal. Note that write handshaking may occur on both data ports (A and B). For a write handshake, CA2 or CB2 serve as the data ready output and can operate in either the handshake mode or the pulse mode. The data taken signal is received by CA1 or CB1. The data taken signal sets a flag in the interrupt flag register and clears the data ready output signal. Note that the selection of read or write handshake operating modes (CA1, CA2, CB1, and CB2) is accomplished by the peripheral control register (PCR).

#### INTERRUPT OPERATION

There are three basic operations: setting the flag within the interrupt flag register (IFR), enabling the interrupt by way of a corresponding bit in the interrupt enable register (IER), and signaling the microprocessor with an interrupt request (IRQ). An interrupt flag can be set by conditions internal to the chip or by inputs to the chip from external sources. Normally, an interrupt flag remains set until the interrupt is serviced. To determine the source of an interrupt, the micro-processor must examine each flag in order, from highest to lowest priority. This is accomplished by reading the contents of the interrupt flag register into the microprocessor accumulator, shifting the contents either left or right, and then using conditional branch instructions to detect an active interrupt. Each interrupt flag has a corresponding interrupt enable bit in the interrupt enable register. The enable bits are controlled by the microprocessor (set or reset). If an interrupt flag is HIGH (logic 1), and the corresponding interrupt enable bit is

HIGH (logic 1), the interrupt request (IRQ) will go LOW (logic 0). IRQ is an open-collector output that can be in a wire-OR logic state with other devices within the system.

All interrupt flags are contained within a single interrupt flag register. Bit 7 of this register will be HIGH (logic 1) whenever an interrupt flag is set, thus allowing convenient polling of several devices within a system to determine the source of the interrupt.

The interrupt flag register (IFR) and interrupt enable register (IFR) format and operation is shown in Figures 28 and 29, respectively. The interrupt flag register may be read directly by the micrprocessor, and individual flag bits may be cleared by writing a 1 into the appropriate bit of the IFR. Bit 7 of the IFR indicates the status of the interrupt request (IRQ) output. Bit 7 corresponds to the following logic function: IRQ = IFR6 x IER6 + IFR5 x IER5 + IFR4 x IER4 + IFR3 x IER3 + IFR2 x IER2 + IFR1 x IER1 + IFR0 x IER0. Note x = Logic-AND, + = Logic-OR.

Bit 7 is not a flag. For this reason, bit 7 is not directly cleared by writing a "1" into its bit position. It can be cleared, however, by clearing all the flags within the register, or by disabling all active interrupts as presented in the next section.

#### TIMER OPERATION

Timer 1 Operation - Interval timer T1 consists of two 8-bit latches and a 16-bit counter. The latches serve to store data that is to be loaded into the counter. Once the counter is loaded under program control, it decrements at a phase 2 (Ø2) clock rate. Upon reaching zero, an interrupt flag is set, causing interrupt request (IRQ) to go LOW (logic 0), if the corresponding interrupt enable bit is set. Once the timer reaches a count of zero, it will either disable any further interrupts (provided it has been programmed to do so), or it will automatically transfer the contents of the latches into the counter and proceed to decrement again. The counter may also be programmed to invert the output signal on PB7 each

time it reaches a count of zero. Additional control bits are provided in the auxiliary control register (bits 6 and 7) to allow selection of timer 1 operating modes.

It should be noted that the microprocessor does not write directly into the low-order counter (T1C-L). Instead, this half of the counter is loaded automatically from the low-order register when the microprocessor writes into the high-order register and counter. In fact, it may not be necessary to write to the low-order register in some applications, since the timing operation is triggered by writing to the high-order register and counter.

Timer 1 One-Shot Mode - Interval timer T1 may operate in the one-shot mode which allows the generation of a single interrupt flag each time the timer is loaded. The timer can also be programmed to produce a single negative pulse on data port line PB7.

To generate a single interrupt, it is required that bits 6 and 7 of the auxiliary control register be LOW (logic 0). The low-order T1 counter (T1C-L) or the loworder T1 latch (T1L-L) must then be loaded with the low-order count value. Note that a load to T1C-L is effectively a load to T1L-L. Next, the high-order count value must be loaded into the highorder T1 counter (T1C-H), at which time the value is simultaneously loaded into high-order T1 latch (T1L-H). During this load sequence, the contents of T1L-L is transferred to T1C-L. The counter will start counting down on the next Ø2 clock following the load sequence into T1C-H, and will decrement at the Ø2 clock rate. Once the T1 counter reaches a zero count, the interrupt flag is set. To generate a negative pulse on data port line PB7, the sequence is identical to the above except bit 7 of the auxiliary control register must be HIGH (logic 1). Data port line PB7 will then go LOW (logic 0) following the load to T1C-H, and will go HIGH (logic 1) again when the counter reaches a zero count. Once set, the T1 interrupt flag is reset by either loading T1C-H, which starts a new count, or by reading T1C-L.

Timer 1 Free-Run Mode - An important advantage within the VL65C22 is the

VL6522•VL65C22 **V** 

ability of the latches associated with the T1 counter to provide a continuous series of evenly spaced interrupts or a square wave on data port line PB7. It should also be noted that the continuous series of interrupts and square waves are not affected by variations in the microprocessor interrupt response time. These advantages are all produced in the freerun mode. When operating in the freerun mode, the interrupt flag is set and the signal on PB7 is inverted each time the counter reaches a count of zero. In the free-run mode, however, the counter does not continue to decrement after reaching a zero count. Instead, the counter automatically transfers the contents of the latch into the counter (16 bits) and then decrements from the new count value. As can be seen, it is not necessary to reload the timer in order to set the interrupt flag on the next count of zero. When set, the interrupt flag can be cleared by either reading T1C-L, by writing directly into the interrupt flag register (IFR), as will be discussed later, or by a load into T1C-H when a new count value is desired

Since the interval timers are all retriggerable, reloading the counter will always reinitialize the time-out period. Should the microprocessor continue to reload the counter before it reaches zero, counter time-out can be prevented. Timer 1 is able to operate in this manner provided the microprocessor writes into the highorder counter (T1C-H).

By loading the latches only, the microprocessor can access the timer during each count-down operation without affecting the time-out in progress. In this way, data loaded into the latches will determine the length of the next subsequent time-out period. This capability is of value in the free-run mode with the output enabled. In the free-run mode, the signal on data port line PB7 is inverted and the interrupt flag is set with each counter time-out. When the microprocessor responds to the interrupts with new data for the latches, it can determine the period of the next half-cycle during each half-cycle of the output signal on line PB7. In this way, complex waveforms can be generated.

Timer 2 Operation - Timer 2 operates in the one-shot mode only (as an interval timer), or as a pulse counter for counting negative pulses on data port line PB6. A single control bit within the auxiliary control register is used to select between these two modes. Timer 2 is made up of a write-only low-order latch (T2L-L), a read-only low-order counter (T2C-L), and a read/write high-order counter (T2C-H). This 16-bit counter decrements at a Ø2 clock rate.

Timer 2 One-Shot Mode - Operation of Timer 2 in the one-shot mode is similar to Timer 1. That is, for each load T2C-H operation. Timer 2 sets the interrupt flag for each countdown to zero. However, after a time-out, the T2 counters roll over to all ones (FFF16) and continue to decrement. This twos-complement decrement allows the user to determine how long the T2 interrupt flag has been set. Since the interrupt flag logic is disabled after the initial interrupt set (zero count), further interrupts cannot be set by a subsequent count to zero. To enable the interrupt flag logic, the microprocessor must reload T2C-H. The interrupt flag is cleared by either reading T2C-L or by loading T2C-H.

Timer 2 Pulse Counting Mode - In the pulse counting mode, timer 2 counts a predetermined number of negative-going pulses on data port line PB6. To accomplish this, a count number is loaded into T2C-H, which clears the interrupt flag logic and starts the counter to decrement each time a negative pulse is applied to data port line PB6. When the T2 counter reaches a count of zero, the interrupt flag is set and the counter continues to decrement with each pulse on PB6. To enable the interrupt flag for subsequent countdowns, it is necessary to reload T2C-H. The decrement pulse on line PB6 must be LOW (logic 0) during the leading edge of the Ø2 clock.

#### SHIFT REGISTER OPERATION AND MODES

Shift Register Operation - The shift register performs bidirectional serial data transfers on line CB2. These transfers are controlled by an internal modulo-8 counter. Shift pulses can be applied to the CB1 line for controlling external devices. Each shift register operating mode is controlled by control bits within the auxiliary control register. Shift Register Input Modes (Shift Register Disabled, 000) - In the 000 mode, the shift register is disabled from all operation. The microprocessor can read or write the shift register, but shifting is disabled and both CB1 and CB2 are controlled by bits in the peripheral control register (PCR). The shift register interrupt flag is held LOW (disabled).

Shift-In (Counter T2 Control, 001) - In this mode, the shifting rate is controlled by the low-order eight bits of counter T2. Shift pulses are generated on the CB1 line to control shifting in external devices. The time between transitions of the CB1 output clock is determined by the Ø2 clock period and the contents of the low-order T2 latch (N). Shifting occurs by writing or reading the shift register. Data is shifted into the loworder bit first, and is then shifted into the next higher order bit on the negativegoing edge of each clock pulse. Input data should change before the positivegoing edge of the CB1 clock pulse. This data is then shifted into the shift register during the Ø2 clock cycle following the positive-going edge of the CB1 clock pulse. After eight CB1 clock pulses, the shift register interrupt flag will be set and the IRQ will go LOW (logic 0).

Shift In (Ø2 Clock Control, 010) - In this mode, the shift rate is controlled by the Ø2 clock frequency. Shift pulses are generated on the CB1 line to control shifting in external devices. Timer 2 operates as an independent interval timer and has no influence on the shift register. Shifting occurs by reading or writing the shift register. Data is shifted into the low-order bit first, and is then shifted into the next higher order bit on the trailing edge of the Ø2 clock pulse. After eight clock pulses, the shift register interrupt flag will be set and output clock pulses on the CB1 line will stop.

Shift In (External CB1 Clock Control, 011) - In this mode, CB1 serves as an input to the shift register. In this way, an external device can load the shift register at its own pace. The shift register counter will interrupt the microprocessor after each eight bits have been shifted in. The shift register counter does not stop the shifting operation; its function is simply that of a pulse counter. Reading or writing the shift register resets the interrupt flag and initializes the counter to count another eight pulses. Note that data is shifted during the first Ø2 clock cycle following the positive-going edge of the CB1 shift pulse. For this reason, data



must be held stable during the first full cycle following CB1 going high.

Shift Out (Free Running at T2 Rate, 100) -This mode is similar to mode 101 in which the shifting rate is determined by T2. However, in mode 100 the shift register counter does not stop the shifting operation. Since shift register bit 7 (SR7) is recirculated back into bit 0, the eight bits loaded into the Shift Register will be clocked onto the CR2 line repetitively. In this mode, the shift register counter is disabled and IRQ is never set. Shift Out (T2 Control, 101) - In this mode, the shift rate is controlled by T2 (as in mode 100). However, with each read or write of the shift register, the shift register counter is reset and eight bits are shifted onto the CB2 line. At the same time, eight shift pulses are placed on the CB1 line to control shifting in external devices. After the eight shift pulses, the shifting is disabled, the interrupt flag is set, and CB2 will remain at the last data level.

Shift Out (Ø2 Clock Control, 110) - In this mode, the shift rate is controlled by the system Ø2 clock.

Shift Out (External CB1 Clock Control, 111) - In this mode, shifting is controlled by external pulses applied to the CB1 line. The shift register counter sets the interrupt flag for each eight-pulse count, but does not disable the shifting function. Each time the microprocessor reads or writes to the shift register, the interrupt flag is reset and the counter is initialized to begin counting the next eight pulses on the CB1 line. After eight shift pulses, the interrupt flag is set. The microprocessor can then load the shift register with the next eight bits of data.

# TABLE 1. PERIPHERAL INTERFACE CHARACTERISTICS

## TA = 0°C to 70°C, VCC = 5 V $\pm$ 5%

| Symbol | Parameter                                                      | Min      | Max  | Unit |
|--------|----------------------------------------------------------------|----------|------|------|
| tR, tF | Rise and Fall Time for CA1, CB1, CA2 and CB2 Input Signals     |          | 1.0  | μS   |
| tCA2   | Delay Time, Clock Negative Transition to CA2 Negative          |          | 1.0  | μS   |
|        | Transition (Read Handshake or Pulse Mode)                      |          |      |      |
| tRS1   | Delay Time, Clock Negative Transition to CA2 Positive          |          | 1.0  | μS   |
|        | Transition (Pulse Mode)                                        |          |      |      |
| tRS2   | Delay Time, CA1 Active Transition to CA2 Positive Transition   |          | 2.0  | μS   |
|        | (Handshake Mode)                                               |          |      |      |
| tWHS   | Delay Time, Clock Positive Transition to CA2 or CB2 Negative   | 0.05     | 1.0  | μS   |
|        | Transition (Write Handshake)                                   |          |      |      |
| tDS    | Delay Time, Peripheral Data Valid to CB2 Negative Transition   | 0.20     | 1.5  | μS   |
| tRS3   | Delay Time, Clock Positive Transition to CA2 or CB2 Positive   |          | 1.0  | μS   |
|        | Transition (Pulse Mode)                                        |          |      |      |
| tRS4   | Delay Time, CA1 or CB1 Active Transition to CA2 or CB2         |          | 2.0  | μS   |
|        | Positive Transition (Handshake Mode)                           |          |      |      |
| t21    | Delay Time Required from CA2 Output to CA1 Active              | 400      |      | nS   |
|        | Transition (Handshake Mode)                                    |          |      |      |
| tlL    | Set-up Time, Peripheral Data Valid to CA1 or CB1 Active        | 300      |      | nS   |
|        | Transition (Input Latching)                                    |          |      |      |
| tSR1   | Shift-Out Delay Time - Time from Ø2 Falling Edge to CB2        |          | 300  | nS   |
|        | Data Out                                                       |          |      |      |
| tSR2   | Shift-In Set-up Time - Time from CB2 Data In to Ø2 Rising Edge | 300      |      | nS   |
| tSR3   | External Shift Clock (CB1) Set-up Time Relative to Ø2          | 100      | tCYC | nS   |
|        | Trailing Edge                                                  |          |      |      |
| _tIPW  | Pulse Width - PB6 Input Pulse                                  | 2 x tCYC |      |      |
| tICW   | Pulse Width - CB1 Input Clock                                  | 2 x tCYC |      |      |
| tIPS   | Pulse Spacing - PB6 Input Pulse                                | 2 x tCYC |      |      |
| tICS   | Pulse Spacing - CB1 Input Pulse                                | 2 x tCYC |      |      |
| tAL    | CA1, CB1 Set Up Prior to Transition to Arm Latch               | 300      |      | nS   |
| tPDH   | Peripheral Data Hold After CA1, CB1 Transition                 | 150      |      | nS   |



# FIGURE 2. TIMING FOR READ HANDSHAKE, PULSE MODE



#### FIGURE 5. TIMING FOR WRITE HANDSHAKE, HANDSHAKE MODE



#### FIGURE 6. PERIPHERAL DATA INPUT LATCHING TIMING

| PA, PB<br>PERIPHERAL<br>INPUT DATA | 2.0V<br>0.8V<br>tIL                                                      |
|------------------------------------|--------------------------------------------------------------------------|
| CA1, CB1<br>INPUT LATCH<br>CONTROL |                                                                          |
| FIGURE 7. TIMIN                    | G FOR SHIFT OUT WITH INTERNAL OR EXTERNAL SHIFT CLOCKING                 |
| Ø2                                 |                                                                          |
|                                    | <i></i>                                                                  |
| CB2<br>SHIFT                       | 0.8 V                                                                    |
| DATA (OUT<br>CB1                   | PUT)                                                                     |
| SHIFT CLC<br>(INPUT OF<br>OUTPUT)  | CK<br>DELAY TIME MEASURED FROM<br>THE FIRST Ø2 AFTER CB1<br>FALLING EDGE |



## FIGURE 8. TIMING FOR SHIFT IN WITH INTERNAL OR EXTERNAL SHIFT CLOCKING



FIGURE 9. EXTERNAL SHIFT CLOCK TIMING



#### FIGURE 10. PULSE COUNT INPUT TIMING



| Daniatan |     | RS Co | ding |     | Desister    | Register/Description                      |                      |  |  |  |  |  |
|----------|-----|-------|------|-----|-------------|-------------------------------------------|----------------------|--|--|--|--|--|
| Number   | RS3 | RS2   | RS1  | RS0 | Designation | Write (R/W = L)                           | Read (R/W = H)       |  |  |  |  |  |
| 0        | 0   | 0     | 0    | 0   | ORB / IRB   | Output Register B                         | Input Register B     |  |  |  |  |  |
| 1        | 0   | 0     | 0    | 1   | ORA / IRA   | Output Register A                         | Input Register A     |  |  |  |  |  |
| 2        | 0   | 0     | 1    | 0   | DDRB        | Data Direction Register B                 |                      |  |  |  |  |  |
| 3        | 0   | 0     | 1    | 1   | DDRA        | Data Direction Register A                 |                      |  |  |  |  |  |
| 4        | 0   | 1     | 0    | 0   | T1C - L     | T1 Low-Order Latches T1 Low-Order Counter |                      |  |  |  |  |  |
| 5        | 0   | 1     | 0    | 1   | T1C - H     | T1 High-Order Counter                     |                      |  |  |  |  |  |
| 6        | 0   | 1     | 1    | 0   | T1L - L     | T1 Low-Order Latches                      |                      |  |  |  |  |  |
| 7        | 0   | 1     | 1    | 1   | T1L - H     | T1 High-Order Latches                     |                      |  |  |  |  |  |
| 8        | 1   | 0     | 0    | 0   | T2C - L     | T2 Low-Order Latches                      | T2 Low-Order Counter |  |  |  |  |  |
| 9        | 1   | 0     | 0    | 1   | T2C - H     | T2 High-Order Counter                     |                      |  |  |  |  |  |
| 10       | 1   | 0     | 1    | 0   | SR          | Shift Register                            |                      |  |  |  |  |  |
| 11       | 1   | 0     | 1    | 1   | ACR         | Auxiliary Control Register                |                      |  |  |  |  |  |
| 12       | 1   | 1     | 0    | 0   | PCR         | Peripheral Control Register               |                      |  |  |  |  |  |
| 13       | 1   | 1     | 0    | 1   | IFR         | Interrupt Flag Register                   |                      |  |  |  |  |  |
| 14       | 1   | 1     | 1    | 0   | IER         | Interrupt Enable Register                 |                      |  |  |  |  |  |
| 15       | 1   | 1     | 1    | 1   | ORA / IRA   | Output Register A * Input Register A *    |                      |  |  |  |  |  |

# **TABLE 2. REGISTER SELECT**

\*Note: Same as register 1, except no handshake

# TABLE 3. READ TIMING

|        |                             | VL652 | 2-01 | VL652 | 2-02 | VL65C2 | 22-01 | VL65C22-02 |      | VL65C22-03 |      | VL65C22-04 |      |       |
|--------|-----------------------------|-------|------|-------|------|--------|-------|------------|------|------------|------|------------|------|-------|
| Symbol | Parameter                   | Min.  | Max. | Min.  | Max. | Min.   | Max.  | Min.       | Max. | Min.       | Max. | Min.       | Max. | Units |
| TCY    | Cycle Time                  | 1     | 10   | 0.5   | 10   | 1      | 10    | 0.5        | 10   | 0.33       | 10   | 0.25       | 10   | μs    |
| TACR   | Address Set-up Time         | 180   | -    | 90    | -    | 180    | -     | 90         | -    | 65         | -    | 45         | -    | ns    |
| TCAR   | Address Hold Time           | 0     | -    | 0     | -    | 0      | -     | 0          | -    | 0          | -    | 0          | -    | ns    |
| TPCR   | Peripheral Data Set-up Time | 300   | -    | 150   | -    | 300    | -     | 150        |      | 110        | -    | 75         | -    | ns    |
| TCDR   | Data Bus Delay Time         | -     | 365  | -     | 190  | -      | 365   | -          | 190  | -          | 130  | -          | 90   | ns    |
| THR    | Data Bus Hold Time          | 10    | -    | 10    | -    | 10     | -     | 10         | -    | 10         | -    | 10         | -    | ns    |

# TABLE 4. WRITE TIMING

|        |                                              | VL652 | 2-01 | VL652 | 2-02 | VL65C | 22-01 | VL65C | 22-02 | VL65C22-03 |      | VL65C2 | 22-04 |       |
|--------|----------------------------------------------|-------|------|-------|------|-------|-------|-------|-------|------------|------|--------|-------|-------|
| Symbol | Parameter                                    | Min.  | Max. | Min.  | Max. | Min.  | Max.  | Min.  | Max.  | Min.       | Max. | Min.   | Max.  | Units |
| TCY    | Cycle Time                                   | 1     | 10   | 0.5   | 10   | 1     | 10    | 0.5   | 10    | 0.33       | 10   | 0.25   | 10    | μs    |
| TC     | Ø2 Pulse Width                               | 470   | -    | 240   | -    | 470   | -     | 240   | -     | 180        | -    | 120    | -     | ns    |
| TACW   | Address Set-up Time                          | 180   | -    | 90    | -    | 180   | -     | 90    | -     | 65         | -    | 45     | -     | ns    |
| TCAW   | Address Hold Time                            | 0     | -    | 0     | -    | 0     | -     | 0     | -     | 0          | -    | 0      | -     | ns    |
| TWCW   | R/W Set-up Time                              | 180   | -    | 90    | -    | 180   | -     | 90    | -     | 65         | -    | 45     | -     | ns    |
| TCWW   | R/W Hold Time                                | 0     | -    | 0     | -    | 0     | -     | 0     | -     | 0          | -    | 0      | -     | ns    |
| TDCW   | Data Bus Set-up Time                         | 200   | -    | 90    | -    | 200   | -     | 90    | -     | 65         | -    | 45     |       | ns    |
| THW    | Data Bus Hold Time                           | 10    | -    | 10    | -    | 10    | -     | 10    | -     | 10         | -    | 10     | -     | ns    |
| TCPW   | Peripheral Data Delay Time - 1.0             |       |      | -     | 0.5  | -     | 1.0   | -     | 0.5   | -          | 0.37 | -      | 0.25  | μs    |
| TCMOS  | Peripheral Data Delay Time<br>to CMOS Levels | -     | 2.0  | -     | 1.0  | -     | 2.0   | - 1.0 |       | -          | 0.75 | -      | 0.50  | μs    |

Note: tRISE, tFALL = 10 to 30 ns.

#### FIGURE 11. READ TIMING



**FIGURE 12. WRITE TIMING** TCY (tCYC) TC 2.0 V 2.0 V 2.0 V Ø2 CLOCK - 0.8 V TACW TCAW CHIP SELECTS 2.0 V 2.0 V 0.8 V 0.8 TWCW TDCW TCWW-2.0 V R/W 0.8 V . тнw 2.0 V DATA BUS 81 TCMOS -----VCC TCPW 7 PERIPHERAL 2.0 V DATA 0.8 V

VL6522•VL65C22 🔻 Ē

#### FIGURE 13, REGISTER 0, ORB/IRB



| PIN<br>DATA DIRECTION<br>SELECTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | WRITE                                                                     | READ                                                                                                       |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|
| ddrab = "1" (output)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | MPU WRITES OUTPUT LEVEL<br>(ORB)                                          | MPU READS OUTPUT REGISTER<br>BIT IN ORB. PIN LEVEL HAS NO<br>AFFECT                                        |
| DDRB = "0" (INPUT)<br>(INPUT LATCHING DISABLED)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | MPU WRITES INTO ORB, BUT<br>NO EFFECT ON PIN LEVEL,<br>UNTIL DDRB CHANGED | MPU READS INPUT LEVEL ON PB<br>PIN                                                                         |
| DDRB = "0" (INPUT)<br>(INPUT LATCHING ENABLED)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                           | MPU READS IRB BIT, WHICH IS THE<br>LEVEL OF THE PB PIN AT THE TIME<br>OF THE LAST CB1 ACTIVE<br>TRANSITION |
| And a second sec |                                                                           |                                                                                                            |

#### FIGURE 15. REGISTER 2. DDRB



ASSOCIATED PB PIN IS AN INPUT (HIGH IMPEDANCE) ''0'

ASSOCIATED PB PIN IS AN OUTPUT WHOSE LEVEL IS DETERMINED BY ORB REGISTER BIT 

### FIGURE 17. REGISTER 4, TIMER 1 LOW-ORDER COUNTER



- WRITE 8 BITS LOADED INTO T1 LOW-ORDER LATCHES. LATCH CONTENTS ARE TRANSFERRED INTO LOW-ORDER COUNTER AT THE TIME THE HIGH-ORDER COUNTER IS LOADED (REG 5).
- READ 6 BITS FROM T1 LOW-ORDER COUNTER TRANSFERRED TO MPU. IN ADDITION, T1 INTERRUPT FLAG IS RESET (BIT 6 IN INTERRUPT FLAG REGISTER).

#### FIGURE 14. REGISTER 1, ORA/IRA



| PIN<br>DATA DIRECTION<br>SELECTION               | WRITE                                                                     | READ                                                                                                       |
|--------------------------------------------------|---------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|
| DDRA = "1" (OUTPUT)<br>(INPUT LATCHING DISABLED) | MPU WRITES OUTPUT LEVEL<br>(ORA)                                          | MPU READS LEVEL ON PA PIN                                                                                  |
| DDRA = "1" (OUTPUT)<br>(INPUT LATCHING ENABLED)  |                                                                           | MPU READS IRA BIT WHICH IS THE<br>LEVEL OF THE PA PIN AT THE TIME<br>OF THE LAST CA1 ACTIVE<br>TRANSITION  |
| DDRA = "0" (INPUT)<br>(INPUT LATCHING DISABLED)  | MPU WRITES INTO ORA, BUT<br>NO EFFECT ON PIN LEVEL,<br>UNTIL DDRA CHANGED | MPU READS LEVEL ON PA PIN                                                                                  |
| DDRA = "0" (INPUT)<br>(INPUT LATCHING ENABLED)   |                                                                           | MPU READS IRA BIT, WHICH IS THE<br>LEVEL OF THE PA PIN AT THE TIME<br>OF THE LAST CA1 ACTIVE<br>TRANSITION |

#### FIGURE 16. REGISTER 3, DDRA



PA7

ASSOCIATED PA PIN IS AN INPUT (HIGH IMPEDANCE) "**0**"

114.11

ASSOCIATED PA PIN IS AN OUTPUT WHOSE LEVEL IS DETERMINED BY ORA REGISTER BIT



#### FIGURE 18. REGISTER 5, TIMER 1 HIGH-ORDER COUNTER



WRITE - 8 BITS LODED INTO T1 HIGH-ORDER LATCHES. ALSO, AT THIS TIME BOTH HIGH-AND LOW-ORDER LATCHES TRANSFERRED INTO T1 COUNTER. T1 INTERRUPT FLAG ALSO IS RESET. READ - 8 IBTS FROM T1 HIGH-ORDER COUNTER TRANSFERRED TO MPU.

## FIGURE 20. REGISTER 7, TIMER 1 HIGH-ORDER LATCH



RE

# FIGURE 19. REGISTER 6, TIMER 1 LOW-ORDER LATCH



# FIGURE 21. REGISTER 8, TIMER 2 LOW-ORDER LATCH/COUNTER



WRITE -- 8 BITS LOADED INTO T2 LOW-ORDER LATCH

READ - 8 BITS FROM T2 LOW-ORDER COUNTER TRANSFERRED TO MPU, T2 INTERRUPT FLAG IS RESET.

# FIGURE 22. REGISTER 9, TIMER 2 HIGH-ORDER LATCH/COUNTER

READ - 8 BITS FROM T1 HIGH-ORDER LATCHES TRANSFERRED TO MPU.



- WRITE 8 BITS LOADED INTO T2 HIGH-ORDER COUNTER, ALSO, LOW ORDER LATCH TRANSFERRED TO LOW-ORDER COUNTER, IN ADDITION, T2 INTERRUPT FLAG IS RESET.
- READ 8 BITS FROM T2 HIGH-ORDER COUNTER TRANSFERRED TO MPU.





#### FIGURE 24, REGISTER 11A, AUXILIARY CONTROL REGISTER



#### FIGURE 25. REGISTER 11B, AUXILIARY CONTROL REGISTER



| 4 | 3 | 2 | OPERATION                          |
|---|---|---|------------------------------------|
| 0 | 0 | 0 | DISABLED                           |
| 0 | 0 | 1 | SHIFT IN UNDER CONTROL OF T2       |
| 0 | 1 | 0 | SHIFT IN UNDER CONTROL OF 112      |
| 0 | 1 | 1 | SHIFT IN UNDER CONTROL OF EXT CLK  |
| 1 | 0 | 0 | SHIFT OUT FREE-RUNNING AT T2 RATE  |
| 1 | 0 | 1 | SHIFT OUT UNDER CONTROL OF T2      |
| 1 | 1 | 0 | SHIFT OUT UNDER CONTROL OF 1/2     |
| 1 | 1 | 1 | SHIFT OUT UNDER CONTROL OF EXT CLK |

#### FIGURE 27, REGISTER 13, INTERRUPT FLAG REGISTER

| 7 | 6   | 5   | 4  | Ţ  | 3   | 2   | 1  | 6   |        |                   |                                 |
|---|-----|-----|----|----|-----|-----|----|-----|--------|-------------------|---------------------------------|
| ┱ | ┯   | ┺   | 4  | -  | ۲   | ┱   | Т  | 4   | 4      | SET BY            | CLEARED BY                      |
|   |     |     |    |    |     |     |    |     | - CA2- | CA2 ACTIVE EDGE   | READ OR WRITE<br>REG 1 (ORA)*   |
|   |     |     |    |    |     |     | L  | CA  | 1      | CA1 ACTIVE EDGE   | READ OR WRITE<br>REG 1 (ORA)    |
|   |     |     |    |    |     | μ.  | SH | IF. | REG    | COMPLETE 8 SHIFTS | READ OR WRITE<br>SHIFT REG      |
|   |     |     |    |    | L   | CB2 |    |     |        | CB2 ACTIVE EDGE   | READ OR WRITE ORB*              |
|   |     |     |    | ∟c | 81  | -   |    |     |        | CB1 ACTIVE EDGE   | READ OR WRITE ORB               |
|   |     | L   | тп | ME | R   | 2 - |    |     |        | TIME-OUT OF T2    | READ T2 LOW OR<br>WRITE T2 HIGH |
|   | L   | -TI | ME | R  | 1 - |     |    |     |        | TIME-OUT OF T1    | READ T1 LOW OR<br>WRITE T1 HIGH |
| L | IRC | - c |    |    |     |     | _  |     |        | ANY ENABLED       | CLEAR ALL<br>INTERRUPTS         |

 IF THE CA2/CB2 CONTROL IN THE PCR IS SELECTED AS "INDEPENDENT" INTERRUPT INPUT. THEN READING OR WRITING THE OUTPUT REGISTER ORA/ORB WILL NOT CLEAR THE FLAG BIT. INSTEAD, THE BIT MUST BE CLEARED BY WRITING INTO THE IFR, AS DESCRIBED PREVIOUSLY PREVIOUSLY

#### FIGURE 26. REGISTER 12, PERIPHERAL CONTROL REGISTER



#### FIGURE 28. REGISTER 14, INTERRUPT ENABLE REGISTER



NOTES

- NOTES: 1. IF BIT 7 IS A "0", THEN EACH "1" IN BITS 0 6 DISABLES THE CORRESPONDING INTERRUPT. 2. IF BIT 7 IS A "1", THEN EACH "1" IN BITS 0 6 ENABLES THE CORRESPONDING INTERRUPT.
- ALL OTHER BITS WILL REFLECT THEIR ENABLE/DISABLE STATE.

# DC CHARACTERISTICS:

 $VCC = 5.0 V \pm 5\%, VSS = 0 V, T = 0$ 

0°C to 70°C unless otherwise noted

|        |                                                        |                                              | <del>,                                     </del> | · · · · · · · · · · · · · · · · · · · |      |            |                                    |
|--------|--------------------------------------------------------|----------------------------------------------|---------------------------------------------------|---------------------------------------|------|------------|------------------------------------|
| Symbol |                                                        | Parameter                                    | Min.                                              | Тур.                                  | Max. | Unit       | Conditions                         |
| VIH    | Input High Volt                                        | Input High Voltage                           |                                                   |                                       | VCC  | v          |                                    |
| VIL    | Input Low Volta                                        | ige                                          | - 0.3                                             |                                       | 0.4  | v          | <i>x</i> .                         |
| IIN    | Input Leakage<br>R/W, RES, F                           | Current<br>353 - RS0, CS2, CS1, CA1Ø2        | -                                                 |                                       | ±2.5 | μA         | VIN = 0V to 5.0v<br>VCC = 0V       |
| ITSI   | Input Leakage<br>D7 - D0                               | Current for Off Stat e                       | -                                                 |                                       | ±10  | μA         | VIN = 0.4V to 2.4V<br>VCC = 5.25 V |
| ΠΗ     | Input High Curr<br>PA7-PA0, CA                         | - 100                                        |                                                   | -                                     | μA   | VIN = 2.4V |                                    |
| IIL    | Input Low Curr<br>PA7-PA0, CA                          | -                                            |                                                   | - 1.8                                 | mA   | VIL = 0.4V |                                    |
| VOH    | Output High Voltage<br>PA7-PA0, CA2, PB7-PB0, CB1, CB2 |                                              | 2.4                                               |                                       | -    | v          | VCC = 4.75V<br>ILOAD = - 100 μA    |
| VOL    | Output Low Vo                                          | Itage                                        | -                                                 |                                       | 0.4  | v          | VCC = 4.75V<br>ILOAD = 1.6 mA      |
| IOH    | Output High                                            | PA7-PA0, PB7-PB0<br>( TTL drive ),D7-D0      | - 100                                             |                                       | -    | μA         | VOH = 2.4V                         |
|        | (Sourcing)                                             | PB7-PB0 ( other drive, e.g.,<br>Darlington ) | - 1.0                                             |                                       | -    | mA         | VOH = 1.5V                         |
| IOL    | Output Low Current ( Sinking )                         |                                              | 1.6                                               |                                       | •    | mA         | VOL = 0.4V                         |
| IOFF   | Output Leakage Current (Off State)                     |                                              | -                                                 |                                       | 10   | μA         |                                    |
| PD     | Power Dissipat                                         | ion (VL6522)                                 | -                                                 |                                       | 700  | mW         |                                    |
| ICC    | Power Supply                                           | Current (VL65C22)                            |                                                   | 8                                     |      | mA         |                                    |

# CAPACITANCE: TA = 25°C, f = 1.0 MHz

| Symbol | Parameter          |                                                                        |   | Тур. | Max. | Unit | Conditions               |
|--------|--------------------|------------------------------------------------------------------------|---|------|------|------|--------------------------|
| СІ     | Input Capacitance  | R/W, RES, RS3-RS0,<br>CS2,CS1, D7-D0, CA1,<br>CA2, PA7-PA0,<br>PB7-PB0 | - |      | 7.0  | pF   | VCC = 5.0 V<br>VIN = 0 V |
|        |                    | CB1, CB2                                                               | - |      | 10   | рF   |                          |
|        |                    | Ø2 Input                                                               | - |      | 20   | pF   |                          |
| COUT   | Output Capacitance | A                                                                      | - |      | 10   | pF   |                          |

## Notes:

1. All units are direct current ( DC ).

2. Negative sign indicates outward current flow, positive indicates inward flow.

# **ABSOLUTE MAXIMUM RATINGS**

| Ambient Operating<br>Temperature      | -10 to +80°C   | Stresses above those listed under<br>"Absolute Maximum Ratings" may cause                                       |
|---------------------------------------|----------------|-----------------------------------------------------------------------------------------------------------------|
| Storage Temperature                   | -65 to +150°C  | permanent damage to the device.                                                                                 |
| Supply Voltage to<br>Ground Potential | -0.5 to +7.0 V | These are stress ratings only.<br>Functional operation of this device at<br>these or any other conditions above |
| Applied Output Voltage                | -0.5 to +7.0 V | those indicated on the operational                                                                              |
| Applied Input Voltage                 | -0.5 to +7.0 V | sections of this specification is not                                                                           |
| Power Dissipation                     | 750 mW         | implied and exposure to conditions for<br>extended periods may affect device<br>reliability.                    |

# **VL6765**



# FEATURES

- Address mark detection circuitry
- Software control of
  - -Track stepping rate
  - —Head load time
  - -Head unload time
- · IBM compatible in both single- and double-density format
- Programmable data record lengths: 128, 256, 512, 1024, 2048, 4096 or 8192 bytes/sector
- Multi-sector and multi-track transfer capability
- Controls up to four floppy disk drives .
- Data scan capability-will scan a single sector or an entire track of data fields, comparing on a byte-by-byte basis data in the processor's memory with data read from the disk
- Data transfers in DMA or non-DMA mode
- Parallel seek operations on up to four drives
- Directly compatible with an 8-bit or 16-bit synchronous microprocessor bus including Z-80/8080A/8085A, 8086, and 8088
- Replaces the NEC µPD765A, Intel 8272A, and Rockwell 6765A
- Single phase 4 or 8 MHz clock
- Single +5 volt power supply

ñ

# DESCRIPTION

The VL6765 Double-Density Floppy Disk Controller (DDFDC) interfaces up to four floppy disk drives to an 8-bit or 16-bit microprocessor-based system including Z80, 8080A, 8085A, 8086, and 8088. The DDFDC simplifies the system design by minimizing both the number of external hardware components and software steps needed to implement the floppy disk drive (FDD) interface. Control signals supplied by the DDFDC reduce the number of components required in external phase locked loop and write precompensation circuitry. Memory-mapped registers containing commands, status and data simplify the software interface. Built-in functions reduce the software overhead needed to control the FDD interface. The DDFDC supports both the IBM 3740 Single-Density (FM) and IBM System 34 Double-Density (MFM) formats.

The DDFDC interfaces directly to the synchronous microprocessor bus and operates with 8-bit byte length data transferred on the bus in either DMA or non-DMA mode. In DMA mode, the CPU need only load the command into the DDFDC and all data transfers occur under DMA control. The VL6765 is directly compatible with the Z8410/µPD8257 Direct Memory Access Controller (DMAC). In non-DMA mode, the DDFDC generates an interrupt to the CPU indicating that a byte of data is available.

Controller commands, command or device status, and data are transferred between the DDFDC and the CPU via six internal registers. The Main Status Register (MSR) stores the DDFDC status information while four additional status registers provide result information to the CPU following each controller command. The Data Register (DR) stores actual disk data, parameters, controller commands and FDD status information for use by the CPU.

## PIN DIAGRAM

|     |    | VL6765 | _  |          |
|-----|----|--------|----|----------|
| RST | 1  |        | 40 | vcc      |
| RD  | 2  |        | 39 | RW/SEEK  |
| WR  | 3  |        | 38 | LCT/DIR  |
| CS  | 4  |        | 37 | FR/STP   |
| A0  | 5  |        | 36 | HDL      |
| DO  | 6  |        | 35 | RDY      |
| D1  | Z  |        | 34 | WP/TS    |
| D2  | 8  |        | 33 | FLT/TRK0 |
| D3  | 9  |        | 32 | PS0      |
| D4  | 10 |        | 31 | PS1      |
| D5  | Ш  |        | 30 | WDA      |
| D6  | 12 |        | 29 | USO      |
| D7  | 13 |        | 28 | US1      |
| DRQ | 14 |        | 27 | HD       |
| ACK | 15 |        | 26 | MFM      |
| тс  | 16 |        | 25 | WE       |
| IDX | 17 |        | 24 | vco      |
| INT | 18 |        | 23 | RDD      |
| CLK | 19 |        | 22 | RDW      |
| GND | 20 |        | 21 | WCK      |
|     | 1  |        |    |          |

## ORDER INFORMATION

| Part<br>Number                            | Clock<br>Frequency | Package                                                             |
|-------------------------------------------|--------------------|---------------------------------------------------------------------|
| VL6765-04PC<br>VL6765-04CC<br>VL6765-04QC | 4 MHz              | Plastic DIP<br>Ceramic DIP<br>Plastic Leaded<br>Chip Carrier (PLCC) |
| VL6765-08PC<br>VL6765-08CC<br>VL6765-08QC | 8 MHz              | Plastic DIP<br>Ceramic DIP<br>Plastic Leaded<br>Chip Carrier (PLCC) |

Note:

Operating temperature range: 0°C to +70°C.



#### Figure 1. DDFDC Input and Output Signals



# **PIN DESCRIPTION**

Throughout this document signals are presented using the terms active and inactive, or asserted and negated, independent of whether the signal is active in the high-voltage state or low-voltage state. (The active state of each logic pin is described below.) Active low signals are denoted by a superscript bar.

#### BUS INTERFACE

**D0-D7—Data Lines.** The bidirectional data lines transfer data between the DDFDC and the 8-bit data bus.

**CLK—CLOCK.** The clock is a TTL compatible 4 or 8 MHz square wave signal.

**RST—RESET.** This active high input places the DDFDC in the idle state and resets the output lines to the floppy disk drive (FDD) to the low state. RST does not affect the Step Rate Time (SRT), Head Unload Time (HUT) or Head Load Time (HLT) set by a Specify command. If RDY goes high while RST is high, the DDFDC will assert INT within 1.024 ms. This interrupt can be cleared by issuing a Sense Interrupt Status command.

 $\overline{\text{CS}}$ —Chip Select. The DDFDC is selected when the  $\overline{\text{CS}}$  input is low.

A0—Data/Status Register Select. This input selects the Data or Status Register for reading from or writing to. When A0 = high, the Data Register is selected and the state of  $\overline{RD}$  or  $\overline{WR}$  determines whether it is a read ( $\overline{RD}$  = low) or a write ( $\overline{WR}$  = low)

operation. When A0 = low, the Status Register is selected. This register may only be read ( $\overline{RD}$  = low); the state  $\overline{WR}$  = low is invalid when the Status Register is selected.

**INT—Interrupt Request.** This active high output is the interrupt request generated by the DDFDC to the CPU. INT is asserted upon completion of some DDFDC commands and before a data byte is transferred between the DDFDC and the data bus (in the Non-DMA mode).

**RD**—**Read.** This active low input defines the data bus transfer as a read cycle. When low, the data transfer is from the DDFDC to the data bus.

**WR**—Write. This active low input defines the data bus transfer as a write cycle. When low, the data transfer is from the data bus to the DDFDC.

#### DIRECT MEMORY ACCESS CONTROLLER (DMAC) INTERFACE

**DACK**—**DMA Acknowledge.** The DMA transfer acknowledge signal is a TTL compatible input generated by the DMA controller (DMAC) controlling the DDFDC. The DMA cycle is active when DACK is low and the DDFDC is performing a DMA transfer.

**DRQ—Data DMA Request.** The transfer request signal is a TTL compatible output generated by the DDFDC to request a data transfer operation under control of the DMAC (in the DMA mode). The request is active when DRQ = high. The signal is reset inactive when DMA Acknowledge (DACK) is asserted (low).



TC—Terminal Count. This input signal is issued to the DDFDC when the DMA transfer for a channel is complete. The signal is active high concurrent with the DACK input when the DMA operation is complete as a result of that transfer.

#### FDD SERIAL DATA INTERFACE

**RDD—Read Data.** Read Data input from the floppy disk drive (FDD) containing clock and data bits.

**RDW—Read Data Window.** Data Window input generated by the Phase Locked Loop (PLL) and used to sample data from the FDD.

VCO-Voltage Controlled Oscillator Sync. This output signal inhibits the VCO in the PLL circuit when low and enables the VCO in the PLL circuit when high. This inhibits RDD and RDW from being generated until valid data is detected from the FDD.

**WCK—Write Clock.** This input clock determines the Write Data rate to the FDD. The data rate is 500 KHz in the FM mode (MFM = low) and 1 MHz in the MFM mode (MFM = high). The pulse width is 250 ns (typical) in both modes.

WDA—Write Data. Serial write data output to the FDD containing both clock and data bits.

**WE—Write Enable.** This output signal enables the Write Data into the FDD when high.

**PS0-PS1—Preshift.** These outputs are encoded to convey write compensation status during the MFM mode to determine early, late or normal times as follows:

|                              | Preshift | Outputs                               |  |
|------------------------------|----------|---------------------------------------|--|
| Write Precompensation Status | PS0      | PS1                                   |  |
| Normal                       | 0        | 0                                     |  |
| Late                         | 0        | 1                                     |  |
| Early                        | 1        | 0                                     |  |
| Invalid                      | 1        | 1                                     |  |
| 0 = Low, 1 = High            |          | · · · · · · · · · · · · · · · · · · · |  |

## FDD STATUS INTERFACE

**RDY—Ready.** An active high input signal indicates the FDD is ready to send data to, or receive data from, the DDFDC.

**IDX—Index.** An active high input signal from the FDD indicates the index hole is under the index sensor. Index is used to synchronize DDFDC timing.

**RW/SEEK—Read Write/Seek.** Mode selection signal to the FDD which controls the multiplexer from the multiplexed signals. When **RW**/SEEK is low, the Read/Write mode is commanded; when **RW**/SEEK is high, the Seek mode is commanded.

| <b>RW/SEEK</b> | Mode       | Active FDD Interface Signals |
|----------------|------------|------------------------------|
| Low            | Read/Write | WP, FLT, LCT, FR             |
| High           | Seek       | TS, TRKO, DIR, STP           |

WP/TS—Write Protect/Two Side. An active high multiplexed input signal from the FDD. In the Read/Write mode, WP/TS high indicates the media is write-protected. In the Seek mode, WP/TS high indicates the media is two-sided.

**FLT/TRK0—Fault/Track Zero.** An active high multiplexed input from the FDD. In the Read/Write mode ( $\overline{RW}$ /SEEK = low), FLT/TRK0 high indicates an FDD fault. In the Seek mode, FLT/TRK0 high indicates that the read/write head is positioned over track zero.

LCT/DIR—Low Current/Direction. A multiplexed output to the FDD. In the Read/Write mode, LCT/DIR is low when the read/write head is to be positioned over the inner tracks and the LCT/DIR is high when the head is to be positioned over the outer tracks. In the Seek mode, LCT/DIR controls the head direction. When LCT/DIR is high, the head steps to the outside of the disk; when LCT/DIR is low, the head steps to the inside of the disk.

FR/STP—Fault Reset/Step. A multiplexed output to the FDD. In the Read/Write mode, FR/STP high resets the fault indicator in the FDD. An FR pulse is issued at the beginning of each read or write command prior to issuing HDL. In the Seek mode, FR/STP provides the step pulses to move the read/write head to another track in the direction indicated by the LCT/DIR signal.

HDL—Head Load. An active high output to notify the FDD that the read/write head should be loaded (placed in contact with the media). A low level indicates the head should be unloaded.

Figure 2. Typical VL6765 Application





**HD**—**Head Select.** An output to the FDD to select the proper read/write head. Head One is selected when HD = high and Head Zero is selected when HD = low.

**US0-US1—Unit Select.** Output signals for floppy disk drive selection as follows:

| Unit S           | Select | Floppy Disk  |  |  |
|------------------|--------|--------------|--|--|
| USO              | US1    | Drive Select |  |  |
| 0                | 0      | 0            |  |  |
| 0                | 1      | 1            |  |  |
| 1                | 0      | 2            |  |  |
| 1                | 1      | 3            |  |  |
| 0 = Low, 1 = Hic | h      |              |  |  |

**MFM**—**MFM Mode.** Output signal to the FDD to indicate MFM or FM mode. Selects the MFM mode when MFM = high and the FM mode MFM = Low.

VCC-Power. +5 Vdc.

GND-Ground (V<sub>ss</sub>).

Figure 3. DDFDC Block Diagram

#### DDFDC REGISTERS

The DDFDC contains six registers which may be accessed by the processor or DMA controller via the system (i.e., microprocessor) bus: a Main Status Register, a Data Register, and four Result Status Registers. The 8-bit Main Status Register (MSR) contains the status information of the DDFDC, and may be accessed at any time. The 8-bit Data Register, consisting of several registers in a stack with only one register presented to the data bus at a time, stores data, commands, parameters and FDD status information. Bytes of data are read out of, or written into, the Data Register in order to initiate a command or to obtain the results of a command execution.

The read-only Main Status Register facilitates the transfer of data between the system and the DDFDC. The other Status Registers (ST0, ST1, ST2 and ST3) are only available during the result phase, and may be read only after completing a command. The particular command which has been executed determines how many of the Status Registers will be read.





The relationship between the status/data registers and the WR, RD and A0 signals is shown below.

| AO                | RD | WR | Function                  |  |  |
|-------------------|----|----|---------------------------|--|--|
| 0                 | 0  | 0  | lllegal                   |  |  |
| 0                 | 0  | 1  | Read Main Status Register |  |  |
| 0                 | 1  | 0  | lllegal                   |  |  |
| 1                 | 0  | 0  | Illegal                   |  |  |
| 1                 | 0  | 1  | Read from Data Register   |  |  |
| î                 | 1  | 0  | Write into Data Register  |  |  |
| 0 = Low, 1 = High |    |    |                           |  |  |

Table 1 shows each of the status registers used by the DDFDC and each bit assignment within the individual registers. Table 2 defines the symbols used throughout the command definitions. Each register bit symbol is defined in the register descriptions that follow Table 2.

# **REGISTER DEFINITIONS**

#### Main Status Register (MSR)

| 7   | 6   | 5   | 4  | 3   | 2   | 1   | 0   |
|-----|-----|-----|----|-----|-----|-----|-----|
| RQM | DIO | EXM | СВ | D3B | D2B | D1B | D0B |

The Main Status Register (MSR) contains the status information of the DDFDC, and must be read by the processor before each byte is written to, or read from, the Data Register during the command or result phase. MSR reads are not required during the execution phase. The Data Input/Output (DIO) and Request for Master (RQM) bits in the MSR indicate when data is ready and in which direction data will be transferred on the data bus. The maximum time between the last RD or WR during command or result phases and the DIO and RQM getting set or reset is 12 µs. For this reason, every time the MSR is read the processor should wait 12 µs. The maximum time from the trailing edge of the last RD in the result phase to when bit 4 (DDFDC Busy) goes low is also  $12 \mu s$ .

The DIO and RQM timing chart is shown in Figure 4.

#### MSR

#### 7 RQM -Request for Master.

- ō Data Register is not ready.
- Data Register is ready. 1

#### MSR

#### 6 DIO -Data Input/Output.

- Data transfer is from system to the Data Register. 0
- 1 Data transfer is from Data Register to the system.

#### MSR

#### EXM -Execution Mode. (Non-DMA mode only). 5

- ō Execution phase ended, result phase begun.
- Execution phase started. 1

## MSR

#### СВ -Controller (DDFDC) Busy. 4

- ō DDFDC is not busy, will accept a command.
- DDFDC is busy, will not accept a command. 1

# MSR

- --Floppy Disk Drive (FDD) 3 Busv. 3 D3B
- ō FDD 3 is not busy, DDFDC will accept read or write command.
- FDD 3 is busy, DDFDC will not accept read or write 1 command.

#### MSR

- D2B -FDD 2 Busy. 2
- FDD 2 is not busy, DDFDC will accept read or write 0 command.
- FDD 2 is busy. DDFDC will not accept read or write 1 command.

#### MSR

#### 1 D1B -FDD 1 Busy.

- õ FDD 1 is not busy, DDFDC will accept read or write command.
- 1 FDD 1 is busy, DDFDC will not accept read or write command.

#### MSR

#### D0B -FDD 0 Busy. 0

- n FDD 0 is not busy, DDFDC will accept read or write command.
- FDD 0 is busy, DDFDC will not accept read or write 1 command.

## Status Register 0 (ST0)

| 7 | 6       | 5  | 4  | 3    | 2  | 1             | 0 |
|---|---------|----|----|------|----|---------------|---|
|   | <u></u> | 0E | EC |      | ЦD | US<br>US1 US0 |   |
|   |         | 3E | EC | INIT |    |               |   |

The Status Register 0 (ST0) as well as the other status registers (ST1-ST3), are available only during the result phase, and may be read only after completing a command. The particular command executed determines which status registers are used and may be read.

## ST0

- 6 IC -Interrupt Code. 7
- ō Normal Termination (NT). Command was properly exeō cuted and completed.
- Abnormal Termination (AT). Command execution was 0 1 started, but was not successfully completed.
- 0 Invalid Command (IC). Received command was invalid. 1
- Abnormal Termination (AT). The Ready (RDY) signal 1 1 from the FDD changed state during command execution.

#### STO SE

#### -Seek End. 5 ō

- Seek command is not completed. 1
  - Seek command completed by DDFDC.

## STO

#### EC -Equipment Check. 4

- ō No error.
- Either a fault signal is received from the FDD or the track 1 0 signal failed to occur after 256 step pulses (Recalibrate command).



## Table 1. DDFDC Status Register Bit Assignments

|                            | Bit Number |     |     |      |     |     |     |     |  |
|----------------------------|------------|-----|-----|------|-----|-----|-----|-----|--|
| Main Status Register (MSR) | 7          | 6   | 5   | 4    | 3   | 2   | 1   | 0   |  |
| Status Pagistar 0 (ST0)    | RQM        | DIO | EXM | СВ   | D3B | D2B | D1B | D0B |  |
| Status negister 0 (510)    |            |     |     |      |     |     | US  |     |  |
| Status Register 1 (ST1)    | K          |     | SE  | EC   | NH  | HD  | US1 | US0 |  |
| Status Register 2 (ST2)    | EN         | 0   | DE  | OR   | 0   | ND  | NW  | MA  |  |
| Status Register 3 (ST3)    | 0          | СМ  | DD  | WT   | SH  | SN  | BT  | MD  |  |
|                            | FLT        | WP  | RDY | TRK0 | TS  | HD  | US1 | US0 |  |

## Table 2. Command Symbol Description

| Symbol                   | Name                                         | Description                                                                                                                                                                                                                                                                                                                                                                                 |
|--------------------------|----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A0                       | Address Line A0                              | Controls selection of Main Status Register (A0 = low) or Data Register (A0 = high).                                                                                                                                                                                                                                                                                                         |
| D                        | Data                                         | The data pattern which is going to be written into a sector.                                                                                                                                                                                                                                                                                                                                |
| D0-D7                    | Data Bus                                     | 8-bit data bus, where D0 is the least significant data line and D7 is the most significant data line.                                                                                                                                                                                                                                                                                       |
| DTL                      | Data Length                                  | When N is defined as 00, DTL is the number of data bytes to read from or write into the sector.                                                                                                                                                                                                                                                                                             |
| EOT                      | End of Track                                 | The final sector number on a track. During read or write operation, the DDFDC stops data transfer<br>after reading from or writing to the sector equal to EOT.                                                                                                                                                                                                                              |
| GPL                      | Gap Length                                   | The length of Gap 3. During read/write commands this value determines the number of bytes that the VCO will stay low after two CRC bytes. During the Format a Track command it determines the size of Gap 3.                                                                                                                                                                                |
| н                        | Head Address                                 | Head number 0 or 1, as specified in ID field.                                                                                                                                                                                                                                                                                                                                               |
| HD (H)                   | Head                                         | A selected head number 0 or 1 which controls the polarity of pin 27. (H = HD in all command words).                                                                                                                                                                                                                                                                                         |
| HLT                      | Head Load Time                               | The head load time in the FDD (2 to 254 ms in 2 ms increments).                                                                                                                                                                                                                                                                                                                             |
| HUT                      | Head Unload Time                             | The head unload time after a read or write operation has occurred (16 to 240 ms in 16 ms increments).                                                                                                                                                                                                                                                                                       |
| MF                       | FM or MFM Mode                               | When MF = 0, FM mode is selected; and when MF = 1, MFM mode is selected.                                                                                                                                                                                                                                                                                                                    |
| МТ                       | Multi-Track                                  | When MT = 1, a multi-track operation is to be performed. After finishing a read/write operation on side 0, the DDFDC will automatically start searching for sector 1 on side 1.                                                                                                                                                                                                             |
| N                        | Bytes/Sector                                 | The number of data bytes written in a sector.                                                                                                                                                                                                                                                                                                                                               |
| ND                       | Non-DMA Mode                                 | When ND = 1, operation is in the Non-DMA mode; when ND = 0, operation is in the DMA mode.                                                                                                                                                                                                                                                                                                   |
| NTN                      | New Track Number                             | A new track number, which will be reached as a result of the Seek command. Desired head position.                                                                                                                                                                                                                                                                                           |
| PTN                      | Present Track Number                         | The track number at the completion of Sense Interrupt Status command. Present head position.                                                                                                                                                                                                                                                                                                |
| R                        | Record (Sector)                              | The sector number to be read or written.                                                                                                                                                                                                                                                                                                                                                    |
| R/W                      | Read/Write                                   | Either read (R) or write (W) signal.                                                                                                                                                                                                                                                                                                                                                        |
| ST                       | Sectors/Track                                | The number of sectors per track.                                                                                                                                                                                                                                                                                                                                                            |
| SK                       | Skip                                         | Skip Deleted Data Address Mark.                                                                                                                                                                                                                                                                                                                                                             |
| SRT                      | Step Rate Time                               | The stepping rate for the FDD (1 to 16 ms in 1 ms increments). Stepping rate applies to all drives $(F = 1 ms, E = 2 ms, etc.)$                                                                                                                                                                                                                                                             |
| ST0<br>ST1<br>ST2<br>ST3 | Status 0<br>Status 1<br>Status 2<br>Status 3 | Four registers which store the status information after a command has been executed. This information is available during the result phase after command execution. These registers should not be confused with the Main Status Register (selected by $A0 = low$ ). ST0-ST3 may be read only after a command has been executed and contain information relevant to that particular command. |
| STP                      | Sector Test Process                          | During a Scan command, if STP = 01, the data in contiguous sectors is compared byte by byte with data sent from the processor (or DMA controller); and if STP = 02, then alternate sectors are read and compared.                                                                                                                                                                           |
| Т                        | Track Number                                 | The current/selected track number of the medium (0-255).                                                                                                                                                                                                                                                                                                                                    |
| US0,US1                  | Unit Select                                  | A selected drive number (0-3).                                                                                                                                                                                                                                                                                                                                                              |



#### ST0

- 3 NR -Not Ready.
- ō FDD is ready.
- FDD is not ready at issue of read or write command. If 1 a read or write command is issued to side 1 of a singlesided drive, this bit is also set.

#### ST0

| 2 | HD | Head | Address. | (At | Interru | pt) | ì |
|---|----|------|----------|-----|---------|-----|---|
|   |    |      |          |     |         |     |   |

- õ Head Select 0.
- Head Select 1. 1

#### ST0

- 0 US -Unit Selected. (At Interrupt). 1
- ō FDD 0 selected. 0
- 0 1 FDD 1 selected.
- 1 0 FDD 2 selected.
- 1 1 FDD 3 selected.

#### Status Register 1 (ST1)

| 7  | 6 | 5  | 4  | 3 | 2  | 1  | 0  |
|----|---|----|----|---|----|----|----|
| EN | 0 | DE | OR | 0 | ND | NW | MA |

#### ST1

- EN -End of Track. 7
- ō No error.
- DDFDC attempted to access a sector beyond the last 1 sector of a track.

#### ST1 6

-Not Used. Always Zero.

#### ST1

- 5 DE -Data Error.
- ō No error.
- 1 DDFDC detected a CRC error in ID field or the Data field.

#### ST1

OR -Overrun. 4

- õ No error.
- 1 DDFDC was not serviced by the system during data transfers, within a predetermined time interval.

#### ST1 3

-Not Used. Always Zero.

#### ST1

ND 2 ---No Data.

0 No error.

- 3 possible errors. 1
  - 1. DDFDC cannot find sector specified in the Internal Data Register (IDR) during execution of Read Data. Write Deleted Data or Scan commands.
  - 2. DDFDC cannot read ID field without an error during Read ID command.
  - 3. DDFDC cannot find starting sector during execution of Read a Track command.

## ST1

1

#### NW -Not Writable. 1

ō No error.

DDFDC detected a write protect signal from FDD during execution of Write Data, Write Deleted Data or Format a Track commands.

# ST1

#### 0 MA -Missing Address Mark.

- ō No error. 1
  - 2 possible errors.
    - 1. DDFDC cannot detect the ID Address Mark after encountering the index hole twice.
    - 2. DDFDC cannot detect the Data Address Mark or Deleted Data Address Mark. The MD (Missing Address Mark in Data field) of Status Register 2 is also set.

### Status Register 2 (ST2)

| 7 | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|---|----|----|----|----|----|----|----|
| 0 | СМ | DD | WT | SH | SN | BT | MD |

ST2 7

#### -Not Used. Always Zero.

ST2 6

1

#### CM -Control Mark.

- ō No error.
  - DDFDC encountered a sector which contained a Deleted Data Address Mark during execution of a Read Data, Read a Track, or Scan command, or which contained a Data Address Mark during execution of a Read Deleted Data command.

# ST2

- 5 DD -Data Error in Data Field.
- ō No error. 1
  - DDFDC detected a CRC error in the Data field.
- ST2

#### WT -Wrong Track.

ō No error

Contents of T on the disk is different from that stored in IDR. Bit is related to ND (Bit 2) of Status Register 1.

# ST2

4

1

SH -Scan Equal Hit. 3 ō

- No "equal" condition during a scan command. 1
  - "Equal" condition satisfied during a scan command.

ST2 2

1

#### SN -Scan Not Satisfied.

- ō No error.
  - DDFDC cannot find a sector on the track which meets the scan command condition.



#### ST2

#### BT -Bad Track. 1

- ō No error.
- 1 Contents of T on the disk is different from that stored in the IDR and T = FF. Bit is related to ND (Bit 2) of Status Register 1.

#### ST2

#### 0 MD -Missing Address Mark in Data Field.

- ō No error.
- DDFDC cannot find a Data Address Mark or Deleted Data 1 Address Mark during a data read from the disk.

#### Status Register 3 (ST3)

| 7   | 6  | 5   | 4    | 3  | 2  | 1   | 0   |
|-----|----|-----|------|----|----|-----|-----|
| FLT | WP | RDY | TRK0 | TS | HD | US1 | US0 |

Status Register 3 (ST3) holds the results of the Sense Drive Status command.

#### ST3

#### 7 FLT -Fault.

- ō Fault (FLT) signal from the FDD is low.
- 1 Fault (FLT) signal from the FDD is high.

#### ST3

#### 6 WP -Write Protect.

- ō Write Protect (WP) signal from the FDD is low.
- 1 Write Protect (WP) signal from the FDD is high.

#### ST3

- 5 RDY -Readv.
- ō Ready (RDY) signal from the FDD is low.
- 1 Ready (RDY) signal from the FDD is high.

#### ST3

- TRK0 -Track 0. 4
- 0 Track 0 (TRK0) signal from the FDD is low.
- 1 Track 0 (TRK0) signal is from the FDD is high.

#### ST3

- 3 TS -Two Side.
- ō Two Side (TS) signal from the FDD is low.
- 1 Two Side (TS) signal from the FDD is high.

#### ST3

#### HD -Head Select. 2

- ō Head Select (HD) signal to the FDD is low.
- 1 Head Select (HD) signal to the FDD is high.

#### ST3

- US1 -Unit Select 1. 1
- 0 Unit Select 1 (US1) signal to the FDD is low.
- Unit Select 1 (US1) signal to the FDD is high. 1 ST3

#### 0 US0

- -Unit Select 0. 0
- Unit Select 0 (US0) signal to the FDD is low.
- 1 Unit Select 0 (US1) signal to the FDD is high.

# COMMAND SEQUENCE

The DDFDC is capable of performing 15 different commands. Each command is initiated by a multi-byte transfer of data from the system. After command execution, the result of the command may be a multi-byte transfer of data back to the system. Because of this multi-byte transfer of information between the DDFDC and the system, each command consists of three phases:

Command Phase-The DDFDC receives all information required to perform a particular operation from the system.

Execution Phase-The DDFDC performs the instructed operation.

Result Phase-After completion of the operation, status and other housekeeping information are made available to the system.

The bytes of data sent to the DDFDC to form a command, and read out of the DDFDC in the result phase, must occur in the order shown for each command sequence. That is, the command code byte must be sent first followed by the other bytes in the specified sequence. All command bytes must be written and all result bytes must be read in each phase. After the last byte of data in the command phase is received by the DDFDC, the execution phase starts. Similarly, when the last byte of data is read out in the result phase, the command is ended and the DDFDC is ready to accept a new command. A command can be terminated by asserting the Terminal Count (TC) signal to the DDFDC. This ensures that the processor can always get the DDFDC's attention even if the command in process hangs up in an abnormal manner

### COMMAND DESCRIPTION

#### **READ DATA**

A command set of nine bytes places the DDFDC into the Read Data mode. After the Read Data command has been received the DDFDC loads the head (if it is unloaded), waits the specified Head Settling Time (defined in the Specify command), then begins reading ID Address Marks and ID fields from the disk. When the current sector number (R) stored in the ID Register (IDR) matches the sector number read from the disk, the DDFDC transfers data from the disk Data field to the data bus.

After completion of the read operation from the current sector, the DDFDC increments the Sector Number (R) by one, and the data from the next sector is read and output to the data bus. This continuous read function is called a "Multi-Sector Read Operation." The Read Command terminates after reading the last data byte from sector R when R = EOT. ST0 bits 7 and 6 are set to 0 and 1, respectively, and ST1 bit 7 (EN) is set to a 1.

The Read Data command can also be terminated by a high Terminal Count (TC) signal. TC should be issued at the same time that the DACK for the last byte of data is sent. Upon receipt of TC, the DDFDC stops outputting data to the data bus, but continues to read data from the current sector, checks CRC (Cyclic Redundancy Count) bytes, and then at the end of that sector terminates the Read Data command and sets bits 7 and 6 in ST0



to 0. The amount of data which can be handled with a single command to the DDFDC depends upon MT (Multi-Track), MF (MFM/FM), and N (Number of Bytes/Sector) values. Table 3 shows the transfer capacity.

The multi-track function (MT) allows the DDFDC to read data from both sides of the disk. For a particular track, data is transferred starting at sector 1, side 0 and completed at sector L, side 1 (sector L = last sector on the side). This function pertains to only one track (the same track) on each side of the disk.

When N = 0 in command byte 6 (FM mode), the Data Length (DTL) in command byte 9 defines the data length that the DDFDC must treat as a sector. If DTL is smaller than the actual data length in a sector, the data beyond the DTL is not sent to the data bus. The DDFDC reads (internally) the complete sector, performs the CRC check, and depending upon the manner of command termination, may perform a multi-sector Read operation. When N is ncn-zero (MFM mode), DTL has no meaning and should be set to FF.

At the completion of the Read Data command, the head is not unloaded until the Head Unload Time (HUT) interval defined in the Specify command has elapsed. The head settling time may be avoided between subsequent reads if the processor issues another command before the head unloads. This time savings is considerable when disk contents are copied from one drive to another.

If the DDFDC detects the Index Hole twice in succession without finding the right sector (indicated in R), then the DDFDC sets the No Data (ND) flag in Status Register 1 (ST1) to a 1, sets Status Register 0 (ST0) bits 7 and 6 to 0 and 1, respectively, and terminates the Read Data command.

After reading the ID and Data fields in each sector, the DDFDC checks the CRC bytes. If a read error is detected (incorrect CRC in ID field), the DDFDC sets the Data Error (DE) flag in ST1 to a 1, sets the Data Error in Data Field (DD) flag in ST2 to a 1 if a CRC error occurs in the Data field, sets bits 7 and 6 in ST0 to 0 and 1, respectively, and terminates the command.

#### Table 3. DDFDC Transfer Capacity

| If the DDFDC reads a Deleted Data Address Mark from the disk,    |
|------------------------------------------------------------------|
| and the Skip Deleted Data Address Mark bit in the first command  |
| byte is not set (SK = 0), then the DDFDC reads all the data in   |
| the sector, sets the Control Mark (CM) flag in ST2 to a 1, and   |
| terminates the command. If SK = 1, the DDFDC skips the sec-      |
| tor with the Deleted Data Address Mark and reads the next sec-   |
| tor. The CRC bits in the deleted data field are not checked when |
| SK = 1.                                                          |

During disk data transfers from the DDFDC to the system, the DDFDC must be serviced by the system within 27  $\mu$ s in the FM mode, and within 13  $\mu$ s in the MFM mode, otherwise the DDFDC sets the Over Run (OR) flag in ST1 to a 1, sets bits 7 and 6 in ST0 to 0 and 1, respectively, and terminates the command.

If the processor terminates a read (or write) operation in the DDFDC, then the ID information in the result phase is dependent upon the state of the hT bit in the first command byte and the End of Track (EOT) byte. Table 4 shows the values for Track Number (T), Head Number (H), Sector Number (R), and Number of Data Bytes/Sector (N), when the processor terminates the command.

#### **Command Phase:**

| R/W                | BYTE | 7                  | 6      | 5      | 4   | 3     | 2      | 1       | 0   |
|--------------------|------|--------------------|--------|--------|-----|-------|--------|---------|-----|
| w                  | 1    | MT                 | MF     | SK     | 0   | 0     | 1      | 1       | 0   |
|                    | 2    | х                  | Х      | Х      | х   | х     | HD     | US1     | US0 |
| 3 Track Number (T) |      |                    |        |        |     |       |        |         |     |
|                    | 4    | Head Number (H)    |        |        |     |       |        |         |     |
|                    | 5    | Sec                | tor Nu | mber   | (R) |       |        |         |     |
|                    | 6    | Nun                | nber o | f Data | Byt | es pe | er Sec | tor (N) |     |
|                    | 7    | End of Track (EOT) |        |        |     |       |        |         |     |
|                    | 8    | Gap Length (GPL)   |        |        |     |       |        |         |     |
|                    | 9    | Data               | a Leng | th (D  | ΓL) |       |        |         |     |

| Multi-Track | MFM/FM | Bytes/Sector | Maximum Transfer Capacity                  | Final Sector Read |
|-------------|--------|--------------|--------------------------------------------|-------------------|
| (MT)        | (MF)   | (N)          | (Bytes/Sector) (Number of Sectors)         | from Disk         |
| 0           | 0      | 00           | (128) $(26) = 3,328$                       | 26 at Side 0      |
|             | 1      | 01           | (256) $(26) = 6,656$                       | or 26 at Side 1   |
| 1           | 0<br>1 | 00<br>01     | (128) $(52) = 6,656(256)$ $(52) = 13,312$  | 26 at Side 1      |
| 0           | 0      | 01           | (256) $(15) = 3,840$                       | 15 at Side 0      |
| 0           | 1      | 02           | (512) $(15) = 7,680$                       | or 15 at Side 1   |
| 1           | 0<br>1 | 01<br>02     | (256) $(30) = 7,680(512)$ $(30) = 15,360$  | 15 at Side 1      |
| 0           | 0      | 02           | (512) $(8) = 4.096$                        | 8 at Side 0       |
| 0           | 1      | 03           | (1024) $(8) = 8.192$                       | or 8 at Side 1    |
| 1           | 0<br>1 | 02<br>03     | (512) $(16) = 8,192(1024)$ $(16) = 16,384$ | 8 at Side 1       |



| Comman                  | d Phase ID             | · .                                          | T                      | Result                | Phase ID                |                             |
|-------------------------|------------------------|----------------------------------------------|------------------------|-----------------------|-------------------------|-----------------------------|
| Multi-<br>Track<br>(MT) | Head<br>Number<br>(HD) | Final Sector Transferred<br>to/from Data Bus | Track<br>Number<br>(T) | Head<br>Number<br>(H) | Sector<br>Number<br>(R) | No. of<br>Data Bytes<br>(N) |
|                         | 0                      | Less than EOT                                | NC                     | NC                    | R + 1                   | NC                          |
|                         | 0                      | Equal to EOT                                 | T + 1                  | NC                    | 01                      | NC                          |
| 0                       | 1                      | Less than EOT                                | NC                     | NC                    | R + 1                   | NC                          |
|                         | 1                      | Equal to EOT                                 | T + 1                  | NC                    | 01                      | NC                          |
|                         | 0                      | Less than EOT                                | NC                     | NC                    | R + 1                   | NC                          |
|                         | 0                      | Equal to EOT                                 | NC                     | LSB                   | 01                      | NC                          |
| 1                       | 1                      | Less than EOT                                | NC                     | NC                    | R + 1                   | NC                          |
|                         | 1                      | Equal to EOT                                 | T + 1                  | LSB                   | 01                      | NC                          |

#### Table 4. DDFDC Command Termination Values

Notes:

1. NC (No Change): The same value as the one at the beginning of command execution.

2. LSB (Least Significant Bit): The least significant bit of H is complemented.

#### **Result Phase:**

| R                                                                                                              | 1                                                                                                               | Status Register 0 (ST0)             |
|----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|-------------------------------------|
|                                                                                                                | 2                                                                                                               | Status Register 1 (ST1)             |
|                                                                                                                | 3                                                                                                               | Status Register 2 (ST2)             |
|                                                                                                                | 4                                                                                                               | Track Number (T)                    |
|                                                                                                                | 5                                                                                                               | Head Number (H)                     |
|                                                                                                                | 6                                                                                                               | Sector Number (R)                   |
|                                                                                                                | 7                                                                                                               | Number of Data Bytes per Sector (N) |
| the second s | the second se |                                     |

#### WRITE DATA

A command set of nine bytes places the DDFDC in the Write Data mode. After the Write Data command has been received the DDFDC loads the head (if it is unloaded), waits the specified Head Settling Time (defined in the Specify command), then begins reading ID fields from the disk. When the four bytes (T, H, R, N) loaded during the command match the four bytes of the ID field from the disk, the DDFDC transfers data from the data bus to the disk Data field.

After writing data into the current sector, the DDFDC increments the sector number (R) by one, and writes into the Data field in the next sector. The DDFDC continues this multi-sector write operation until the last byte is written to sector R when R = EOT. ST0 bits 7 and 6 are set to 0 and 1, respectively, and ST1 bit 7 (EN) is set to a 1.

The command can also be terminated by a high on Terminal Count (TC). If TC is sent to the DDFDC while writing into the current sector, then the remainder of the Data field is filled with 00 (zeros). In this case, ST0 bits 7 and 6 are set to 0 and the command is terminated.

The DDFDC reads the ID field of each sector and checks the CRC bytes. If the DDFDC detects a read error (incorrect CRC) in one

of the ID fields, it terminates the Write Data command, sets the DE flag in ST1 to a 1, and sets bits 7 and 6 in ST0 to 0 and 1, respectively.

The Write Data command operates in much the same manner as the Read Data command. Refer to the Read Data command for the handling of the following items:

- Transfer Capacity
- · End of Track (EN) flag
- No Data (ND) flag
- · Head Unload Time (HUT) interval
- ID information when the processor terminates command (see Table 4)
- Definition of Data Length (DTL) when N = 0 and when N  $\neq$  0

In the Write Data mode, data transfers from the data bus to the DDFDC must occur within 27  $\mu$ s in the FM mode, and within 13  $\mu$ s in the MFM mode. If the time interval between data transfers is longer than this, then the DDFDC terminates the Write Data command, sets the Over Run (OR) flag in ST1 to a 1, and sets bits 7 and 6 in ST0 to 0 and 1, respectively.

#### **Command Phase:**

| R/W | BYTE | 7                | 6                  | 5      | 4    | 3    | 2      | 1       | 0                            |
|-----|------|------------------|--------------------|--------|------|------|--------|---------|------------------------------|
| w   | 1    | МТ               | MF                 | 0      | 0    | 0    | 1      | 0       | 1                            |
|     | 2    | х                | х                  | х      | x    | х    | HD     | US1     | US0                          |
|     | 3    | Trac             | k Nun              | nber ( | T)   |      |        |         |                              |
|     | 4    | Head Number (H)  |                    |        |      |      |        |         |                              |
|     | 5    | Sec              | Sector Number (R)  |        |      |      |        |         |                              |
|     | 6    | Nun              | ber of             | f Data | Byte | es p | er Sec | tor (N) |                              |
|     | 7    | End              | End of Track (EOT) |        |      |      |        |         |                              |
|     | 8    | Gap Length (GPL) |                    |        |      |      |        |         |                              |
|     | 9    | Data             | a Leng             | th (D1 | TL)  |      |        |         |                              |
|     |      |                  |                    |        |      |      |        |         | and the second second second |



### **Result Phase:**

| R | 1                                                                                                               | Status Register 0 (ST0)             |
|---|-----------------------------------------------------------------------------------------------------------------|-------------------------------------|
|   | 2                                                                                                               | Status Register 1 (ST1)             |
|   | 3                                                                                                               | Status Register 2 (ST2)             |
|   | 4                                                                                                               | Track Number (T)                    |
|   | 5                                                                                                               | Head Number (H)                     |
|   | 6                                                                                                               | Sector Number (R)                   |
|   | 7                                                                                                               | Number of Data Bytes per Sector (N) |
|   | the second se |                                     |

## WRITE DELETED DATA

The Write Deleted Data command is the same as the Write Data command except a Deleted Data Address Mark is written at the beginning of the Data field instead of the normal Data Address Mark.

#### **Command Phase:**

| R/W | BYTE | 7                  | 6                | 5      | 4    | 3    | 2      | 1       | 0   |  |
|-----|------|--------------------|------------------|--------|------|------|--------|---------|-----|--|
| w   | 1    | MT MF 0 0 1 0 0 1  |                  |        |      |      |        |         | 1   |  |
|     | 2    | х                  | х                | х      | х    | х    | HD     | US1     | US0 |  |
|     | 3    | Trac               | Track Number (T) |        |      |      |        |         |     |  |
|     | 4    | Hea                | Head Number (H)  |        |      |      |        |         |     |  |
|     | 5    | Sect               | or Nu            | mber ( | R)   |      |        |         |     |  |
|     | 6    | Num                | ber of           | Data   | Byte | es p | er Sec | tor (N) |     |  |
|     | 7    | End of Track (EOT) |                  |        |      |      |        |         |     |  |
|     | 8    | Gap Length (GPL)   |                  |        |      |      |        |         |     |  |
|     | 9    | Data Length (DTL)  |                  |        |      |      |        |         |     |  |

## Result Phase:

| R | 1 | Status Register 0 (ST0)            |
|---|---|------------------------------------|
|   | 2 | Status Register 1 (ST1)            |
|   | 3 | Status Register 2 (ST2)            |
|   | 4 | Track Number (T)                   |
|   | 5 | Head Number (H)                    |
|   | 6 | Sector Number (R)                  |
|   | 7 | Number of Data Bytes per Sector(N) |

#### READ DELETED DATA

The Read Deleted Data command is the same as the Read Data command except that if SK = 0 when the DDFDC detects a **Data Address Mark** at the beginning of a Data field, it reads all the data in the sector and sets the CM flag in ST2 to a 1, and then terminates the command. If SK = 1, then the DDFDC skips the sector with the **Data Address Mark** and reads the next sector.

## Command Phase:

| R/W | BYTE | 7                  | 6                | 5      | 4    | 3    | 2      | 1       | 0   |
|-----|------|--------------------|------------------|--------|------|------|--------|---------|-----|
| w   | 1    | MT                 | 0                | 0      |      |      |        |         |     |
|     | 2    | х                  | x                | х      | x    | х    | HD     | US1     | US0 |
|     | 3    | Trac               | Track Number (T) |        |      |      |        |         |     |
|     | 4    | Head Number (H)    |                  |        |      |      |        |         |     |
|     | 5    | Sect               | or Nu            | mber   | (R)  |      |        |         |     |
|     | 6    | Num                | ber of           | Data   | Byte | es p | er Sec | tor (N) |     |
|     | 7    | End of Track (EOT) |                  |        |      |      |        |         |     |
|     | 8    | Gap Length (GPL)   |                  |        |      |      |        |         |     |
|     | 9    | Data               | Leng             | th (DT | "L)  |      |        |         |     |
|     |      |                    |                  |        |      |      |        |         |     |

#### **Result Phase:**

| R | 1 | Status Register 0 (ST0)             |
|---|---|-------------------------------------|
|   | 2 | Status Register 1 (ST1)             |
|   | 3 | Status Register 2 (ST2)             |
|   | 4 | Track Number (T)                    |
|   | 5 | Head Number (H)                     |
|   | 6 | Sector Number (R)                   |
|   | 7 | Number of Data Bytes per Sector (N) |

## **READ A TRACK**

The Read a Track command is similar to the Read Data command except that this is a continuous read operation where all Data fields from each of the sectors on a track are read and transferred to the data bus. Immediately after encountering the Index Hole, the DDFDC starts reading the Data fields as continuous blocks of data. This command terminates when the number of sectors read is equal to EOT. Multi-track operations are not allowed with this command.

If the DDFDC finds an error in the ID or Data CRC check bytes, it continues to read data from the track. The DDFDC compares the ID information read from each sector with the value stored in the IDR, and sets the ND flag in ST1 to a 1 if there is no match.

If the DDFDC does not find an ID Address Mark on the disk after it encounters the Index Hole for the second time it terminates the command, sets the Missing Address Mark (MA) flag in ST1 to a 1, and sets bits 7 and 6 of ST0 to 0 and 1, respectively.



#### **Command Phase:**

| R/W | BYTE | 7                  | 6                | 5    | 4    | 3    | 2      | 1       | 0   |  |
|-----|------|--------------------|------------------|------|------|------|--------|---------|-----|--|
| w   | 1    | 0 MF SK 0 0 0 1 0  |                  |      |      |      |        |         |     |  |
|     | 2    | х                  | X                | х    | х    | х    | HD     | US1     | US0 |  |
|     | 3    | Trac               | Track Number (T) |      |      |      |        |         |     |  |
|     | 4    | Head Number (H)    |                  |      |      |      |        |         |     |  |
|     | 5    | Sec                | tor Nu           | mber | (R)  |      |        |         |     |  |
|     | 6    | Nun                | nber of          | Data | Byte | es p | er Sec | tor (N) |     |  |
|     | 7    | End of Track (EOT) |                  |      |      |      |        |         |     |  |
|     | 8    | Gap Length (GPL)   |                  |      |      |      |        |         |     |  |
|     | 9    | Data Length (DTL)  |                  |      |      |      |        |         |     |  |

#### **Result Phase:**

| R | 1 | Status Register 0 (ST0)             |
|---|---|-------------------------------------|
|   | 2 | Status Register 1 (ST1)             |
|   | 3 | Status Register 2 (ST2)             |
|   | 4 | Track Number (T)                    |
|   | 5 | Head Number (H)                     |
|   | 6 | Sector Number (R)                   |
|   | 7 | Number of Data Bytes per Sector (N) |
|   |   |                                     |

#### READ ID

The two-byte Read ID command returns the present position of the read/write head. The DDFDC obtains the value from the first ID field it is able to read, sets bits 7 and 6 in ST0 to 0 and terminates the command.

If no proper ID Address Mark is found on the disk before the Index Hole is encountered for the second time then the Missing Address Mark (MA) flag in ST1 is set to a 1, and if no data is found then the ND flag in ST1 is also set to a 1. Bits 7 and 6 in ST0 are set to 0 and 1, respectively and the command is terminated.

During this command there is no data transfer between DDFDC and the data bus except during the result phase.

#### **Command Phase:**

| R/W | BYTE | 7 | 6  | 5 | 4 | 3 | 2  | 1   | 0   |
|-----|------|---|----|---|---|---|----|-----|-----|
| w   | 1    | 0 | MF | 0 | 0 | 1 | 0  | 1   | 0   |
|     | 2    | Х | x  | х | x | х | HD | US1 | US0 |

#### **Result Phase:**

| and the second se |   |                                     |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|-------------------------------------|
| R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1 | Status Register 0 (ST0)             |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 2 | Status Fiegister 1 (ST1)            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 3 | Status Register 2 (ST2)             |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 4 | Track Number (T)                    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 5 | Head Number (H)                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 6 | Sector Number (R)                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 7 | Number of Data Bytes per Sector (N) |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |                                     |

#### FORMAT A TRACK

The six-byte Format a Track command formats an entire track. After the Index Hole is detected, data is written on the disk: Gaps, Address Marks, ID fields and Data fields; all are recorded in either the double-density IBM System 34 format (MF = 1) or the single-density IBM 3740 format (MF = 0). The particular format written is also controlled by the values of Number of Bytes/Sector (N), Sectors/Track (ST), Gap Length (GPL) and Data Pattern (D) which are supplied by the processor during the command phase. The Data field is filled with the data pattern stored in D.

The ID field for each sector is supplied by the processor in response to four data requests per sector issued by the DDFDC. The type of data request depends upon the Non-DMA flag (ND) in the Specify command. In the DMA mode (ND = 0), the DDFDC asserts the DMA Request (DRQ) output four times per sector. In the Non-DMA mode (ND = 1), the DDFDC asserts Interrupt Request (INT) output four times per sector.

The processor must write one data byte in response to each request, sending (in the consecutive order) the Track Number (T), Head Number (H), Sector Number (R) and Number of Bytes/Sector (N). This allows the disk to be formatted with non-sequential sector numbers, if desired.

The processor must send new values for T, H, R, and N to the DDFDC for each sector on the track. For sequential formatting R is incremented by one after each sector is formatted, thus, R contains the total numbers of sectors formatted when it is read during the result phase. This incrementing and formatting continues for the whole track until the DDFDC, upon encountering the Index Hole for the second time, terminates the command and sets bits 7 and 6 in ST0 to 0.

If the Fault (FLT) signal is high from the FDD at the end of a write operation, the DDFDC sets the Equipment Check (EC) flag in ST0 to a 1, sets bits 7 and 6 of ST0 to 0 and 1, respectively, and terminates the command. Also, a low (RDY) signal at the beginning of a command execution phase causes bits 7 and 6 of ST0 to be set to 0 and 1, respectively.

Table 5 shows the relationship between N, ST, and GPL for various disk and sector sizes.

#### **Command Phase:**

| R/W | BYTE | 7                | 6                              | 5      | 4 | 3 | 2  | 1   | 0   |
|-----|------|------------------|--------------------------------|--------|---|---|----|-----|-----|
| w   | 1    | 0                | MF                             | 0      | 0 | 1 | 1  | 0   | 1   |
|     | 2    | х                | x                              | Х      | x | х | HD | US1 | US0 |
|     | 3    | Nun              | Number of Bytes per Sector (N) |        |   |   |    |     |     |
|     | 4    | Sec              | Sectors per Track (ST)         |        |   |   |    |     |     |
|     | 5    | Gap Length (GPL) |                                |        |   |   |    |     |     |
|     | 6    | Data             | a Patte                        | rn (D) | ) |   |    |     |     |



|              |                  |                             | No. of Data         |                       | Gap Leng                           | Gap Length (GPL) <sup>4</sup>  |         |  |
|--------------|------------------|-----------------------------|---------------------|-----------------------|------------------------------------|--------------------------------|---------|--|
| Disk<br>Size | Mode             | Sector Size<br>Bytes/Sector | Bytes/Sector<br>(N) | Sectors/Track<br>(ST) | Read/Write<br>Command <sup>1</sup> | Format<br>Command <sup>2</sup> | Remarks |  |
|              |                  | 128                         | 00                  | 1A                    | 07                                 | 1B                             |         |  |
|              |                  | 256                         | 01                  | 0F                    | 0E                                 | 2A                             |         |  |
|              | 54               | 512                         | 02                  | 08                    | 1B                                 | 3A                             |         |  |
|              | FIVI             | 1024                        | 03                  | 04                    | 47                                 | 8A                             |         |  |
|              |                  | 2048                        | 04                  | 02                    | C8                                 | FF-                            | 1       |  |
|              | 1                | 4096                        | 05                  | Q1                    | C8                                 | FF                             | ļ       |  |
| 8″           |                  | 256                         | 01                  | 1A                    | 0E                                 | 36                             |         |  |
|              | MFM <sup>3</sup> | 512                         | 02                  | 0F                    | 1B                                 | 54                             |         |  |
|              |                  | 1024                        | 03                  | 08                    | 35                                 | 74                             | 1       |  |
|              |                  | 2048                        | 04                  | 04                    | 99                                 | FF                             |         |  |
|              |                  | 4096                        | 05                  | 02                    | C8                                 | FF                             |         |  |
|              |                  | 8192                        | 06                  | 01                    | C8                                 | FF                             |         |  |
|              |                  | 128                         | 00                  | 12                    | 07                                 | 09                             |         |  |
|              |                  | 128                         | 00                  | 10                    | 10                                 | 19                             |         |  |
|              | EM               | 256                         | 01                  | 08                    | 18                                 | 30                             |         |  |
|              | FIVI             | 512                         | 02                  | 04                    | 46                                 | 87                             |         |  |
|              |                  | 1024                        | 03                  | 02                    | C8                                 | FF                             |         |  |
|              |                  | 2048                        | 04                  | 01                    | C8                                 | FF                             |         |  |
| 51⁄4″        |                  | 256                         | 01                  | 12                    | 0A                                 | 0C                             |         |  |
|              |                  | 256                         | 01                  | 10                    | 20                                 | 32                             |         |  |
|              | MENA             | 512                         | 02                  | 08                    | 2A                                 | 50                             |         |  |
|              | INIT'IVIO        | 1024                        | 03                  | 04                    | 80                                 | F0                             |         |  |
|              |                  | 2048                        | 04                  | 02                    | C8                                 | FF                             |         |  |
|              |                  | 4096                        | 05                  | 01                    | C8                                 | FF                             |         |  |

#### Table 5. Standard Floppy Disk Sector Size Relationship

#### Notes:

1. Suggested values of GPL in Read or Write commands to avoid overlapping between Data field and ID field of contiguous sections.

2. Suggested values of GPL in Format a Track command.

3. In MFM mode the DDFDC cannot perform a read/write/format operation with 128 bytes/sector (N = 00).

4. Values of ST and GPL are in hexadecimal.

#### **Result Phase:**

R

|   | 1 | Status Register 0 (ST0)              |
|---|---|--------------------------------------|
|   | 2 | Status Register 1 (ST1)              |
|   | 3 | Status Register 2 (ST2)              |
|   | 4 | Track Number (T)*                    |
|   | 5 | Head Number (H)*                     |
|   | 6 | Sector Number (R)*                   |
|   | 7 | Number of Data Bytes per Sector (N)* |
| 1 |   | has an experience in this assumed    |

\* The ID information has no meaning in this command.

#### SCAN COMMANDS

The scan commands compare data read from the disk to data supplied from the data bus. The DDFDC compares the data, and looks for a sector of data which meets the conditions of  $D_{FDD} = D_{BUS}$ ,  $D_{FDD} \leq D_{BUS}$ , or  $D_{FDD} \geq D_{BUS}$  (D = the data pattern in hexadecimal). A magnitude comparison is performed (FF = largest number, 00 = smallest number). The hexadecimal byte of FF either from the bus or from FDD can be used as a mask byte because it always meets the condition of the compare. After a whole sector of data is compared, if the conditions are not met, the sector number is incremented (R + STP  $\rightarrow$  R), and the scan operation is continued. The scan operation continues until one of the following events occur: the conditions for scan are met (equal, low or equal), or high or equal), the last sector on the track is reached (EOT), or TC is received.



If conditions for scan are met, the DDFDC sets the Scan Hit (SH) flag in ST2 to a 1, and terminates the command. If the conditions for scan are not met between the starting sector (as specified by R) and the last sector on the track (EOT), then the DDFDC sets the Scan Not Satisfied (SN) flag in ST2 to a 1, and terminates the command. The receipt of TC from the processor or DMA controller during the scan operation will cause the DDFDC to complete the comparison of the particular byte which is in process, and then to terminate the command. Table 6 shows the status of bits SH and SN under various conditions of scan.

#### Table 6. Scan Status Codes

| Command            | Status R    | Commente    |                                                      |
|--------------------|-------------|-------------|------------------------------------------------------|
| Command            | Bit 2 = SN  | Bit 3 = SH  | Commenta                                             |
| Scan Equal         | 0<br>1      | 1<br>0      | $D_{FDD} = D_{BUS}$<br>$D_{FDD} \oplus D_{BUS}$      |
| Scan Low or Equal  | 0<br>0<br>1 | 1<br>0<br>0 | $\begin{array}{llllllllllllllllllllllllllllllllllll$ |
| Scan High or Equal | 0<br>0<br>1 | 1<br>0<br>0 | $\begin{array}{llllllllllllllllllllllllllllllllllll$ |

If SK = 0 and the DDFDC encounters a Deleted Data Address Mark on one of the sectors, it regards that sector as the last sector of the track, sets the Control Mark (CM) bit in ST2 to a 1 and terminates the command. If SK = 1, the DDFDC skips the sector with the Deleted Data Address Mark, sets the CM flag to a 1 in order to show that a Deleted Sector has been encountered, and reads the next sector.

When either the STP sectors are read (contiguous sectors = 01, or alternate sectors = 02) or MT (Multi-Track) is set, **the last sector on the track must be read.** For example, if STP = 02, MT = 0, the sectors are numbered sequentially 1 through 26, and the scan command starts reading at sector 21. Sectors 21, 23, and 25 are read, then the next sector (26) is skipped and the Index Hole is encountered before the EOT value of 26 can be read. This results in an abnormal termination of the command. If the EOT had been set at 25 or the scanning started at sector 20, then the scan command would be completed in a normal manner.

During a scan command data is supplied from the data bus for comparison against the data read from the disk. In order to avoid having the Over Run (OR) flag set in ST1, data must be available from the data bus in less than 27  $\mu$ s (FM mode) or 13  $\mu$ s (MFM mode). If an OR occurs, the DDFDC terminates the command and sets bits 7 and 6 of ST0 to 0 and 1, respectively.

The following tables specify the command bytes and describe the result bytes for the three scan commands.

## SCAN EQUAL

#### **Command Phase:**

| R/W                                                                                 | BYTE | 7                                    | 6  | 5  | 4 | 3 | 2  | 1       | 0   |  |  |  |
|-------------------------------------------------------------------------------------|------|--------------------------------------|----|----|---|---|----|---------|-----|--|--|--|
| W                                                                                   | 1    | MT                                   | MF | SK | 1 | 0 | 0  | 0       | 1   |  |  |  |
|                                                                                     | 2    | х                                    | х  | x  | х | х | HD | US1     | US0 |  |  |  |
|                                                                                     | 3    | Track Number (T)                     |    |    |   |   |    |         |     |  |  |  |
|                                                                                     | 4    | Head Number (H)<br>Sector Number (R) |    |    |   |   |    |         |     |  |  |  |
|                                                                                     | 5    |                                      |    |    |   |   |    |         |     |  |  |  |
| 6 Number of Data Bytes per Sector (N)<br>7 End of Track (EOT)<br>8 Gap Length (GPL) |      |                                      |    |    |   |   |    | tor (N) |     |  |  |  |
|                                                                                     |      |                                      |    |    |   |   |    |         |     |  |  |  |
|                                                                                     |      |                                      |    |    |   |   |    |         |     |  |  |  |
| 9 Sector Test Process (STP)                                                         |      |                                      |    |    |   |   |    |         |     |  |  |  |

#### **Result Phase:**

| R | 1 | Status Register 0 (ST0)             |
|---|---|-------------------------------------|
|   | 2 | Status Register 1 (ST1)             |
|   | 3 | Status Register 2 (ST2)             |
|   | 4 | Track Number (T)                    |
|   | 5 | Head Number (H)                     |
|   | 6 | Sector Number (R)                   |
|   | 7 | Number of Data Bytes per Sector (N) |
|   |   |                                     |

#### SCAN LOW OR EQUAL

#### **Command Phase:**

| R/W | BYTE | 7                                   | 6  | 5  | 4 | 3 | 2  | 1   | 0   |  |  |  |
|-----|------|-------------------------------------|----|----|---|---|----|-----|-----|--|--|--|
| w   | 1    | мт                                  | MF | SK | 1 | 1 | 0  | 0   | 1   |  |  |  |
|     | 2    | х                                   | х  | x  | x | х | HD | US1 | US0 |  |  |  |
|     | 3    | Track Number (T)                    |    |    |   |   |    |     |     |  |  |  |
|     | 4    | Head Number (H)                     |    |    |   |   |    |     |     |  |  |  |
|     | 5    | Sector Number (R)                   |    |    |   |   |    |     |     |  |  |  |
|     | 6    | Number of Data Bytes per Sector (N) |    |    |   |   |    |     |     |  |  |  |
|     | 7    | End of Track (EOT)                  |    |    |   |   |    |     |     |  |  |  |
|     | 8    | Gap Length (GPL)                    |    |    |   |   |    |     |     |  |  |  |
|     | 9    | Sector Test Process (STP)           |    |    |   |   |    |     |     |  |  |  |

#### **Result Phase:**

| R | 1 | Status Register 0 (ST0)             |
|---|---|-------------------------------------|
|   | 2 | Status Register 1 (ST1)             |
|   | 3 | Status Register 2 (ST2)             |
|   | 4 | Track Number (T)                    |
|   | 5 | Head Number (H)                     |
|   | 6 | Sector Number (R)                   |
|   | 7 | Number of Data Bytes per Sector (N) |
|   |   |                                     |



# SCAN HIGH OR EQUAL

#### Command Phase:

| R/W | BYTE | 7                                   | 6      | 5      | 4    | 3    | 2             | 1 | 0 |  |
|-----|------|-------------------------------------|--------|--------|------|------|---------------|---|---|--|
| w   | 1    | MT                                  | MF     | SK     | 1    | 1    | 1             | 0 | 1 |  |
|     | 2    | х                                   | х      | HD     | US1  | US0  |               |   |   |  |
|     | 3    | Track Number (T)                    |        |        |      |      |               |   |   |  |
|     | 4    | Head Number (H)                     |        |        |      |      |               |   |   |  |
|     | 5    | Sector Number (R)                   |        |        |      |      |               |   |   |  |
|     | 6    | Number of Data Bytes per Sector (N) |        |        |      |      |               |   |   |  |
|     | 7    | End of Track (EOT)                  |        |        |      |      |               |   |   |  |
|     | 8    | Gap Length (GPL)                    |        |        |      |      |               |   |   |  |
|     | 9    | Sec                                 | tor Te | st Pro | cess | (STI | <b>&gt;</b> ) |   |   |  |

#### **Result Phase:**

|   | and a second a second a second as a second a | And the local sector was been and a sector was seen and the sector was seen and the sector was seen as a sector was set of the sector was set |
|---|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R | 1                                            | Status Register 0 (ST0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|   | 2                                            | Status Register 1 (ST1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|   | 3                                            | Status Register 2 (ST2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|   | 4                                            | Track Number (T)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|   | 5                                            | Head Number (H)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|   | 6                                            | Sector Number (R)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|   | 7                                            | Number of Data Bytes per Sector (N)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|   |                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

### SEEK

The three-byte Seek command steps the FDD read/write head from track to track. The DDFDC has four independent Present Track Registers for each drive. They are cleared only by the Recalibrate command. The DDFDC compares the Present Track Number (PTN) which is the current head position with the New Track Number (NTN), and if there is a difference, performs the following operation:

- If PTN < NTN: Sets the direction output (LCT/DIR) high and issues step pulses (FR/STP) to the FDD to cause the read/write head to step in.
- If PTN > NTN: Sets the direction output (LCT/DIR) low and issues step pulses to the FDD to cause the read/write head to step out.

The rate at which step pulses are issued is controlled by the Step Rate Time (SRT) in the Specify command. After each step pulse is issued, NTN is compared against PTN. When NTN = PTN, then the Seek End (SE) flag in ST0 is set to a 1, bits 7 and 6 in ST0 are set to 0, and the command is terminated. At this point DDFDC asserts INT.

The FDD Busy flag (bit 0-3) in the Main Status Register (MSR) corresponding to the FDD performing the Seek operation is set to a 1.

After command termination, all FDD Busy bits set are cleared by the Sense Interrupt Status command.

During the command phase of the Seek operation the DDFDC sets the Controller Busy (CB) flag in the MSR to 1; but during the execution phase the CB flag is set to 0 to indicate DDFDC non-busy. While the DDFDC is in the non-busy state, another Seek command may be issued, and in this manner parallel seek operations may be performed on all drives at once.

No command other than Seek will be accepted while the DDFDC is sending step pulses to any FDD. If a different command type is attempted, the DDFDC will set bits 7 and 6 in ST0 to a 1 and 0, respectively, to indicate an invalid command.

If the FDD is in a not ready state at the beginning of the command execution phase or during the seek operation, then the DDFDC sets the Not Ready (NR) flag in ST0 to a 1, sets ST0 bits 7 and 6 to 0 and 1, respectively, and terminates the command.

If the time to write the three bytes of the Seek command exceeds 150  $\mu$ s, the time between the first two step pulses may be shorter than the Step Rate Time (SRT) defined by the Specify command by as much as 1 ms.

#### **Command Phase:**

| R/W | BYTE | 7                      | 6 | 5 | 4 | 3 | 2 | 1   | 0   |
|-----|------|------------------------|---|---|---|---|---|-----|-----|
| w   | 1    | 0                      | 0 | 0 | 0 | 1 | 1 | 1   | 1   |
|     | 2    | x                      | х | х | X | х | 0 | US1 | US0 |
|     | 3    | New Track Number (NTN) |   |   |   |   |   |     |     |

| Result Phase: None |
|--------------------|
|--------------------|

#### RECALIBRATE

This two-byte command retracts the FDD read/write head to the Track 0 position. The DDFDC clears the contents of the PTN counters, and checks the status of the Track 0 signal from the FDD. As long as the Track 0 signal (TRK0) is low, the direction signal (LCT/DIR) output remains low and step pulses are issued on FR/STP. When TRK0 goes high the DDFDC sets the Seek End (SE) flag in ST0 to a 1 and terminates the command. If the TRK0 is still low after 256 step pulses have been issued, the DDFDC sets Seek End (SE) and Equipment Check (EC) flags in ST0 to 1s, sets bits 7 and 6 of ST0 to 0 and 1, respectively, and terminates the command.

The ability to do overlap Recalibrate commands to multiple FDDs and the loss of the RDY signal, as described in the Seek command, also applies to the Recalibrate command.

#### **Command Phase:**

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2  | 1   | 0   |
|-----|------|---|---|---|---|---|----|-----|-----|
| W   | 1    | 0 | 0 | 0 | 0 | 0 | 1  | 1   | 1   |
|     | 2    | х | Х | Х | x | х | 0. | US1 | US0 |

Result Phase: None.


#### SENSE INTERRUPT STATUS

Interrupt Request (INT) is asserted by the DDFDC when any of the following conditions occur:

- 1. Upon entering the result phase of:
  - a. Read Data command
  - b. Read a Track command
  - c. Read ID command
  - d. Read Deleted Data command
  - e. Write Data command
  - f. Format a Track command
  - g. Write Deleted Data command
  - h. Scan commands
- 2. Ready (RDY) line from the FDD changes state
- 3. Seek or Recalibrate command termination
- 4. During execution phase in the Non-DMA mode

INT caused by reasons 1 and 4 above occur during normal command operations and are easily discernible by the processor. During an execution phase in Non-DMA mode, bit 5 in the MSR is set to 1. Upon entering result phase this bit is set to 0. Reasons 1 and 4 do not require the Sense Interrupt Status command. The interrupt is cleared by reading or writing data to DDFDC. Interrupts caused by reasons 2 and 3 are identified with the aid of the Sense Interrupt Status command. This command resets INT and sets/resets bits 5, 6, and 7 of ST0 to identify the cause of the interrupt. Table 7 defines the seek and interrupt codes.

The Sense Interrupt Status command is used in conjunction with the Seek and Recalibrate commands which have no result phase. When the disk drive has reached the desired head position the DDFDC asserts interrupt output. The host CPU must then issue a Sense Interrupt Status command to determine the actual cause of the interrupt, which could be Seek End or a change in ready status from one of the drives (see example in Figure 4).

Issuing a Sense Interrupt Status command without an interrupt pending is treated as an invalid command.

#### Table 7. ST0 Seek and Interrupt Code Definition for Sense Interrupt Status

|               | Status Reg<br>(ST0) E | ister 0<br>lits  |                                                           |
|---------------|-----------------------|------------------|-----------------------------------------------------------|
| Interru<br>(I | pt Code<br>IC)        | Seek End<br>(SE) |                                                           |
| 7             | 6                     | 5                | Cause                                                     |
| 1             | 1                     | 0                | RDY line changed state, either polarity                   |
| 0             | 0                     | 1                | Normal termination of<br>Seek or Recalibrate<br>command   |
| 0             | 1                     | 1                | Abnormal termination of<br>Seek or Recalibrate<br>command |

#### Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|------|---|---|---|---|---|---|---|---|
| w   | 1    | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |

## **Result Phase:**

| R | 1 | Status Register 0 (ST0)    |
|---|---|----------------------------|
|   | 2 | Present Track Number (PTN) |

#### SPECIFY

The three-byte Specify command sets the initial values for each of the three internal timers. The Head Unload Time (HUT) defines the time from the end of the execution phase of one of the read/write commands to the head unload state. This timer is programmable from 16 to 240 ms in increments of 16 ms (1 = 16 ms,  $2 = 32 \text{ ms}, \dots \text{F} = 240 \text{ ms}$ ).

The Step Rate Time (SRT) defines the time interval between adjacent step pulses. This timer is programmable from 1 to 16 ms in increments of 1 ms (F = 1 ms, E = 2 ms, D = 3 ms, ... 0 = 16 ms.)

The Head Load Time (HLT) defines the time between the Head Load (HDL) signal going high and the start of the read/write operation. This timer is programmable from 2 to 254 ms in increments of 2 ms (01 = 2 ms, 02 = 4 ms, 03 = 6 ms, ... 7F = 254 ms).

The time intervals are a direct function of the clock (CLK on pin 19). Times indicated above are for an 8 MHz clock. If the clock is reduced to 4 MHz (mini-floppy application) then all time intervals are increased by a factor of two.

The choice of DMA or Non-DMA operation is made by the Non-DMA mode (ND) bit. When this bit = 1 the Non-DMA mode is selected, and when ND = 0 the DMA mode is selected.

#### Command Phase:

| R/W | BYTE | 7 | 6  | 5 | 4 | 3 | 2 | 1   | 0  |
|-----|------|---|----|---|---|---|---|-----|----|
| W   | . 1  | 0 | 0  | 0 | 0 | 0 | 0 | 1   | 1  |
|     | 2    |   | SR | Г |   |   |   | HUT |    |
|     | 3    |   | HĽ | г |   |   |   |     | ND |

SRT --- Step Rate Time

HUT-Head Unload Time

HLT — Head Load Time

ND - Non-DMA mode

#### Result Phase: None.



#### Figure 4. Sense Interrupt Status



#### SENSE DRIVE STATUS

This two-byte command obtains and reports the status of the FDDs. Status Register 3 (ST3) is returned in the result phase and contains the drive status.

#### **Command Phase:**

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2  | 1   | 0   |
|-----|------|---|---|---|---|---|----|-----|-----|
| W   | 1    | 0 | 0 | 0 | 0 | 0 | 1  | 0   | 0   |
|     | 2    | х | х | X | x | х | HD | US1 | US0 |

#### **Result Phase:**

| B | 1 | Status Begister 3 (ST3) |
|---|---|-------------------------|
|   | , | Status Hegister 5 (515) |

#### INVALID COMMAND

If an invalid command (i.e., a command not previously defined) is received by the DDFDC, then the DDFDC terminates the command after setting bits 7 and 6 of ST0 to 1 and 0, respectively. The DDFDC does not generate an interrupt during this condition. Bits 6 and 7 (DIO and RQM) in the MSR are both set to a 1 indicating to the processor that the DDFDC is in the result phase and that ST0 must be read. A hex 80 in ST0 indicates that an invalid command was received.

A Sense Interrupt Status command must be sent after a Seek or Recalibrate interrupt, otherwise the DDFDC considers the next command to be an invalid command.

In some applications the user may wish to use this command as a No-Op command, to place the DDFDC in a standby or no operation state.

#### Command Phase:

| R/W | BYTE | 7    | 6      | 5   | 4 | 3 | 2 | 1 | 0 |
|-----|------|------|--------|-----|---|---|---|---|---|
| w   | 1    | Inva | lid Co | des |   |   |   |   |   |

| Result Ph | ase: |                              |
|-----------|------|------------------------------|
| R         | 1    | Status Register 0 (ST0) = 80 |

# **PROCESSOR INTERFACE**

During the command or result phases, the Main Status Register (MSR) must be read by the processor before each byte of information is transferred to, or from, the DDFDC Data Register. After each byte of data is written to, or read from, the Data Register, the processor should wait 12  $\mu$ s before reading the MSR. Bits 6 and 7 in the MSR must be a 0 and 1, respectively, before each command byte can be written to the DDFDC. During the result phase, bits 6 and 7 of the MSR must both be 1s prior to reading each byte from the Data Register onto the data bus. Note that this status reading of bits 6 and 7 of the MSR before each byte transfer to and from the DDFDC is required in only the command and result phases and not during the execution phase.

During the result phase all bytes shown in the result phase must be read by the processor. The Read Data command, for example, has seven bytes of data in the result phase. All seven bytes must be read to successfully complete the Read Data command. The DDFDC will not accept a new command until all seven bytes have been read. Other commands may require fewer bytes to be read during the result phase.



#### Figure 5. DDFDC and System Data Transfer Timing



NOTES



C DATA REGISTER READY FOR NEXT DATA BYTE TO BE READ D DATA REGISTER NOT READY FOR NEXT DATA BYTE TO BE READ

# INTERRUPT REQUEST MODE

During the execution phase, the MSR need not be read. The receipt of each data byte from the FDD is indicated by INT high on pin 18. When the DDFDC is in Non-DMA mode, INT is asserted during the execution phase. When the DDFDC is in the DMA mode, INT is asserted at the result phase. The INT signal is reset by a read (RD low) or write (WR low) of data to the DDFDC. A further explanation of the INT signal is described in the Sense Interrupt Status command on page 16. If the system cannot handle interrupts fast enough (within 13  $\mu$ s for MFM mode or 27  $\mu$ s for FM mode), it should poil bit 7 (RQM) in the MSR. In this case, RQM in the MSR functions as an Interrupt Request (INT). If the RQM bit is not set, the Over Run (OR) flag in ST1 will be set to a 1 and bits 7 and 6 of ST0 will be set to a 0 and 1, respectively.

# DMA MODE

When the DDFDC is in the DMA mode (ND = 0 in the third command byte of the Specify command), DRQ (DMA Request) is asserted during the execution phase (rather than INT) to request the transfer of a data byte between the data bus and the DDFDC.

During a read command, the DDFDC asserts DRQ as each byte of data is available to be read. The DMA controller responds to this request with DACK low (DMA Acknowledge) and RD low (read). When DACK goes low the DMA Request is reset (DRQ low). After the execution phase has been completed (TC high or

the EOT sector is read), INT is asserted to indicate the beginning of the result phase. When the first byte of data is read during the result phase, INT is reset low.

During a write command, the DDFDC asserts DRQ as each byte of data is required. The DMA controller responds to this request with DACK (DMA Acknowledge) and  $\overline{WR}$  low (write). When DACK goes low the DMA Request is reset (DRQ low). After the execution phase has been completed (TC high or the EOT sector is written), INT is asserted. This signals the beginning of the result phase, the INT is reset low.

## FDD POLLING

After the Specify command has been received by the DDFDC, the Unit Select lines (US0 and US1) begin the polling mode. Between commands (and between step pulses in the Seek Command) the DDFDC polls all the FDD's looking for a change in the RDY line from any of the drives. If the RDY line changes state (usually due to the door opening or closing) then the DDFDC asserts INT. When Status Register 0 (ST0) is read (after Sense Interrupt Status command is issued), Not Ready (NR = 1) will be indicated. The polling of the RDY line by the DDFDC occurs continuously between commands, thus notifying the processor which drives are on- or off-line. Each drive is polled every 1.024 ms except during read/write commands.



### Figure 6. DDFDC Formats



#### Figure 7. DDFDC Formats





#### Figure 8. VL6765 DDFDC Interface to Z80





## Figure 9. Clock Timing













#### Figure 12. DMA Operation Timing



## Figure 13. FDD Write Operation Timing



Figure 14. FDD Read Operation Timing







#### Figure 15. Seek Operation Timing



Figure 16. Fault Reset Timing







Figure 18. Terminal Count Timing



## Figure 20. AC Timing Measurement Conditions



INPUTS ARE DRIVEN AT 2.4V FOR A LOGIC "1" AND 0.45 V FOR A LOGIC "0." TIMING MEASUREMENTS ARE MADE AT 2.0V FOR A LOGIC "1" AND 0.8V FOR A LOGIC "0."







CLOCKS ARE DRIVEN AT 3.0V FOR A LOGIC "1" AND 0.3V FOR A LOGIC "0." TIMING MEASUREMENTS ARE MADE AT 2.4V FOR A LOGIC "1" AND 0.65V FOR A LOGIC "0."



# **AC CHARACTERISTICS**

 $(V_{CC} = 5.0 \text{ Vdc} \pm 5\%, V_{SS} = 0 \text{ Vdc}, T_A = 0^{\circ}\text{C to } 70^{\circ}\text{C})$ 

| Ref.<br>Fig. | No. | Charact                       | eristic                                 | Symbol            | Alt. Sym.        | Min.                   | Тур. | Max.   | Unit                     | Test<br>Conditions |
|--------------|-----|-------------------------------|-----------------------------------------|-------------------|------------------|------------------------|------|--------|--------------------------|--------------------|
|              | 1   | Clock Period                  | (8" or 3-1/2" FDD)                      | - toy             | ¢cy              | 120                    | 125  | 500    | ns                       | CLK = 8 MHz        |
| _            | 2   | Clock High                    | (5-1/4" FDD)                            | ter               | <i>d</i> e       | 40                     | 250  |        | ns                       | CLK = 4 MHZ        |
| 8            | 3   | Clock Rise Time               |                                         | torou             | ф.               |                        |      | 20     | ns                       |                    |
|              | 4   | Clock Fall Time               |                                         | tourou            | φ <sub>1</sub>   | _                      |      | 20     | ns                       |                    |
|              | 5   | A0 CS DACK Valid to B         | D Low (Setup)                           |                   | tur              | 0                      |      |        | ns                       |                    |
| 9            | 6   | BD High to A0. CS. DAC        | K Invalid (Hold)                        | toucu             | to AR            | 0                      |      |        | ns                       |                    |
|              | 7   | RD Low Width                  | (,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | to: pu            | tpp              | 250                    |      |        | ns                       |                    |
|              | 8   | RD Low to Data Valid (Ad      |                                         | ten               | _                |                        | 200  | ns     |                          |                    |
|              | 9   | RD High to Output High        | Z                                       | touoz             | tor              | 20                     |      | 100    | ns                       | $C_L = 100  pF$    |
|              | 10  | RD High to INT High           |                                         | touu              |                  | _                      |      | 500    | ns                       | CLK = 8 MHz        |
|              | 11  | A0. CS. DACK Valid to W       | R Low (Setup)                           | termi             | tavar            | 0                      |      |        | ns                       |                    |
|              | 12  | WR High to A0, CS, DAC        | K Invalid (Hold)                        | twucu             | ture ture        | 0                      |      |        | ns                       |                    |
| 10           | 13  | WB Low Width                  |                                         | tunnu             | turn             | 250                    |      |        | ns                       |                    |
| 10           | 14  | Data Valid to WB High (S      | Setup)                                  | touruu            | tow              | 150                    |      |        | ns                       |                    |
|              | 15  | WB High to Data Invalid       | (Hold)                                  | turinov           | two              | 5                      |      |        | ns                       |                    |
|              | 16  | WB High to INT High           |                                         | turner            | two              |                        |      | 500    | ns                       |                    |
|              | 17  | DBO Cycle Time                |                                         | teeu              | *WI              | 13                     |      |        |                          | CLK = 8 MHz        |
|              | 18  | DBO High to BD WB Hi          | ah (Besnonse)                           | tour              | 4MCY             |                        |      | 12     | μ <u>ς</u><br>μ <u>ς</u> |                    |
|              | 10  | DACK Low to DBO Low           | (Delay)                                 | tu a              | *MHW             |                        |      | 200    | ne                       |                    |
| 11           | 199 | DBO High to DACK Low          | (Delay)                                 | tauu              | *AM              | 200                    |      | 200    | ne                       | tau - 125 ns       |
|              | 154 | DBO High to BD Low (D         | tauau                                   | *MA               | 800              |                        |      | ne     | 1 <u>CY - 120 113</u>    |                    |
|              | 20  | DBO High to WB Low (Delay)    |                                         | t                 | MR               | 250                    |      |        | ns                       | CLK = 8 MHz        |
|              |     | Dirice ringin to write tow (E | (8" or 3-1/2" FDD)                      |                   | tov              | -                      | 2    |        | μS                       | MFM = 0            |
|              | 21  | WCK Cycle Time                |                                         |                   | -01              |                        |      |        | μS                       | MFM = 1            |
|              |     |                               | (5-1/4" FDD)                            |                   |                  | _                      | 4    | _      | μS<br>μS                 | MFM = 0<br>MFM = 1 |
|              | 22  | WCK High Width                |                                         | t <sub>KHKL</sub> | to               | 80                     | 250  | 350    | ns                       |                    |
|              | 23  | WCK Rise Time                 |                                         | t <sub>KLKH</sub> | tr               | -                      |      | 20     | ns                       | 1                  |
| 12           | 24  | WCK Fall Time                 |                                         | tкнк              | t <sub>f</sub>   | -                      | _    | 20     | ns                       |                    |
|              | 25  | WCK High to PS0, PS1          | /alid (Delay)                           | t <sub>KHPV</sub> | t <sub>CP</sub>  | 20                     |      | 100    | ns                       |                    |
|              | 25a | WCK High to WE High (I        | Delay)                                  | tDHEN             | t <sub>CWE</sub> | 20                     | _    | 100    | ns                       |                    |
|              | 26  | WCK High to WDA High          |                                         | t <sub>PVDH</sub> | t <sub>CD</sub>  | 20                     |      | 100    | ns                       |                    |
|              | 27  | WDA High Width                |                                         | t <sub>DHDI</sub> | twpp             | t <sub>KHK1</sub> – 50 |      |        | ns                       |                    |
|              |     |                               | (8" or 3-1/2" FDD)                      | twcy              | t <sub>WCY</sub> | -                      | 2    | -      | μS                       | MFM = 0            |
|              | 30  | RDW Cycle Time                | (5-1/4" FDD)                            | -{                |                  |                        | 4    |        | <u>μS</u>                | MFM = 1 $MFM = 0$  |
| 13           |     |                               |                                         |                   |                  |                        | 2    |        | μS                       | MFM = 1            |
| 10           | 31  | RDW Valid to RDD High         | (Setup)                                 | t <sub>wvRH</sub> | t <sub>WRD</sub> | 15                     |      |        | ns                       |                    |
|              | 32  | RDD Low to RDW Invalio        | d (Hold)                                | t <sub>RLWI</sub> | t <sub>RDW</sub> | 15                     |      |        | ns                       |                    |
|              | 33  | RDD High Width                |                                         | t <sub>RHRL</sub> | t <sub>RDD</sub> | 40                     |      |        | ns                       |                    |
|              | 35  | US0, US1 Valid to SEEK        | High (Setup)                            | t <sub>UVSH</sub> | t <sub>US</sub>  | 12                     |      |        | μS                       |                    |
|              | 36  | SEEK Low to US0, US1          | Invalid (Hold)                          | t <sub>SLUI</sub> | t <sub>SU</sub>  | 15                     |      |        | μS                       |                    |
|              | 37  | SEEK High to DIR Valid        | (Setup)                                 | t <sub>SHDV</sub> | t <sub>SD</sub>  | 7                      |      |        | μS                       | ]                  |
| 14           | 38  | DIR Invalid to SEEK Low       | / (Hold)                                | t <sub>DXSL</sub> | t <sub>DS</sub>  | 30                     |      |        | μS                       | CIK = 8 MHz        |
| ••           | 39  | DIR Valid to STP High (S      | Setup)                                  | t <sub>DVTH</sub> | t <sub>DST</sub> | 1                      |      |        | μS                       |                    |
|              | 40  | STP Low to DIR Invalid (      | Hold)                                   | t <sub>TLDX</sub> | t <sub>STD</sub> | 24                     | _    |        | μS                       |                    |
|              | 41  | STP Low to US0, US1 In        | valid (Hold)                            | t <sub>TLUX</sub> | t <sub>STU</sub> | 5                      |      |        | μS                       |                    |
|              | 42  | STP High Width                |                                         | t <sub>THTL</sub> | t <sub>STP</sub> | 6                      | 7    | 8      | μS                       |                    |
|              | 43  | STP Cycle Time                |                                         | t <sub>TCY</sub>  | t <sub>SC</sub>  | 33 <sup>3</sup>        | -    | note 1 | μS                       | ]                  |
| 15           | 44  | FR High Width                 |                                         | t <sub>FHFL</sub> | t <sub>FR</sub>  | 8                      |      | 10     | μs                       |                    |
| 16           | 45  | IDX High Width                |                                         | t <sub>IHIL</sub> | t <sub>IDX</sub> | 10                     |      | -      | t <sub>CY</sub>          | 1                  |
| 17           | 46  | TC High Width                 |                                         | t <sub>THTL</sub> | t <sub>TC</sub>  | 1.                     |      |        | t <sub>CY</sub>          |                    |
| 18           | 47  | RST High Width                |                                         | t <sub>RHRL</sub> | t <sub>RST</sub> | 14                     | _    | -      | t <sub>CY</sub>          |                    |

 t<sub>SC</sub> = 33 μs min. is for different drive units. In the case of the same unit, t<sub>SC</sub> can range from 1 ms to 16 ms with 8 MHz clock period, and 2 ms to 32 ms with 4 MHz clock, under software control.



# **ABSOLUTE MAXIMUM RATINGS\***

| Parameter                   | Symbol           | Value         | Unit |
|-----------------------------|------------------|---------------|------|
| Supply Voltage              | V <sub>cc</sub>  | -0.3 to +7.0  | V    |
| Input Voltage               | V <sub>IN</sub>  | -0.3 to +7.0  | V    |
| Output Voltage              | V <sub>OUT</sub> | -0.3 to +7.0  | v    |
| Operating Temperature Range | T <sub>A</sub>   | 0 to + 70     | C°   |
| Storage Temperature Range   | Т <sub>STG</sub> | - 55 to + 150 | C°   |

\*NOTE: Stresses above those listed under ABSOLUTE MAXI-MUM 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 other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

# **OPERATING CONDITIONS**

| Parameter                    | Range       |
|------------------------------|-------------|
| V <sub>CC</sub> Power Supply | 5.0V ±5%    |
| Operating Temperature        | 0°C to 70°C |

# **DC CHARACTERISTICS**

(V<sub>CC</sub> = 5.0 Vdc  $\pm$  5%, V<sub>SS</sub> = 0 Vdc, T<sub>A</sub> = 0°C to 70°C, unless otherwise noted)

| Parameter                                  | Symbol           | Min            | Max                              | Unit | Test Conditions                                               |
|--------------------------------------------|------------------|----------------|----------------------------------|------|---------------------------------------------------------------|
| Input Low Voltage<br>Logic<br>CLK and WCK  | V <sub>IL</sub>  | - 0.5<br>- 0.5 | 0.8<br>0.65                      | v    |                                                               |
| Input High Voltage<br>Logic<br>CLK and WCK | ViH              | 2.0<br>2.4     | $V_{CC} + 0.5$<br>$V_{CC} + 0.5$ | v    |                                                               |
| Output Low Voltage                         | V <sub>OL</sub>  |                | 0.45                             | v    | $V_{CC} = 4.75V, I_{OL} = 2.0 \text{ mA}$                     |
| Output High Voltage                        | V <sub>OH</sub>  | 2.4            | V <sub>cc</sub>                  | V    | $V_{\rm CC} = 4.75$ V, $I_{\rm OH} = -200 \ \mu$ A            |
| V <sub>CC</sub> Supply Current             | Icc              |                | 150                              | mA   | $V_{CC} = 4.75V$                                              |
| Input Load Current                         | I <sub>IL</sub>  |                | 10                               | μA   | $V_{IN} = V_{CC}$                                             |
| All Inputs                                 |                  |                | - 10                             | μA   | V <sub>IN</sub> = 0V                                          |
| High Level Output Leakage Current          | ILOH             |                | 10                               | μA   | $V_{CC}$ = 0V to 5.25V, $V_{SS}$ = 0V<br>$V_{OUT}$ = $V_{CC}$ |
| Low Level Output Leakage Current           | LOL              |                | - 10                             | μA   | $V_{CC}$ = 0V to 5.25V, $V_{SS}$ = 0V<br>$V_{OUT}$ = +0.45V   |
| Internal Power Dissipation                 | P <sub>INT</sub> | —              | 1.0                              | w    | $T_A = 25^{\circ}C$                                           |

# CAPACITANCE

 $(T_A = 25^{\circ}C; f_c = 1 \text{ MHz}; V_{CC} = 0V)$ 

| Parameter   | Symbol             | Max Limit | Unit |
|-------------|--------------------|-----------|------|
| Clock Input | C <sub>IN(Ø)</sub> | 20        | pF   |
| Input       | CIN                | 10        | pF   |
| Output      | C <sub>OUT</sub>   | 20        | pF   |



# **FEATURES**

**PIN DIAGRAM** 

- CRT Controller Family— Rev E compatibility with SY6845E Rev R compatibility with MC6845 CMOS versions available: CMOS Rev R compatible with MC6845R1, MC6845 and MC146845 CMOS Rev S compatible with HD6845S
- Internal refresh address generation

VL6845R/E

- Character clocks up to 5 MHz
- Bus clocks up to 3 MHz

# DESCRIPTION

The VL6845X and VL68C45X are a family of CRT controllers that are widely used in both bit-mapped and character-mapped applications for both terminals and personal computers. The VL6845 family offers compatibility with the Motorola family of HMOS

# SYSTEM DIAGRAM

controllers while the VL68C45 family allows designs to consume less power through the use of CMOS technology. In addition to compatibility with both the Motorola and Hitachi families, the VL68C45R also contains enhancements found in the MC6845R1. These enhancements allow for higher resolution displays without extra external hardware.







# ORDER INFORMATION

| Part                                     | Clock | Frequency | Part                                                   | Clock                                   | Frequency |                                                                                    |  |  |  |
|------------------------------------------|-------|-----------|--------------------------------------------------------|-----------------------------------------|-----------|------------------------------------------------------------------------------------|--|--|--|
| Number                                   | Bus   | Character | Number                                                 | Bus                                     | Character | Package                                                                            |  |  |  |
| VL6845R-23<br>VL68C45R-23<br>VL68C45S-23 |       | 3 MHz     | VL6845E-33<br>VL6845R-33<br>VL68C45R-33                | VL6845E-33<br>VL6845R-33<br>VL68C45R-33 |           | To specify package type.                                                           |  |  |  |
| VL6845E-24                               | 2 MHZ |           | VL68C45S-33                                            | 3 MHz                                   |           | add the appropriate suffix                                                         |  |  |  |
| VL6845R-24<br>VL68C45R-24<br>VL68C45S-24 |       | 4 MHz     | VL6845E-34<br>VL6845R-34<br>VL68C45R-34<br>VL68C45S-34 |                                         | 4 MHz     | to the part number:<br>PC = Plastic DIP<br>CC = Ceramic DIP<br>QC = Plastic Leaded |  |  |  |
|                                          |       |           | VL6845R-35<br>VL68C45R-35<br>VL68C45S-35               |                                         | 5 MHz     | Chip Carrier (PLCC)                                                                |  |  |  |

Note: Operating temperature range: 0°C to +70°C.

# **PIN DESCRIPTIONS**

| Pin                  | Pin<br>Number | Pin<br>Name             | Description                                                                                                                                                                                                                                                                                 |
|----------------------|---------------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MPU Interfa          |               |                         |                                                                                                                                                                                                                                                                                             |
|                      |               | Fachla                  |                                                                                                                                                                                                                                                                                             |
| E                    | 23            | Enable                  | This capability allows the VL6845 to interface with other non-6800/6500-type microprocessors.                                                                                                                                                                                               |
| R∕₩                  | 22            | Read/Write<br>Control   | Input that, when HIGH, allows the processor to read the data supplied by the VL6845; when this signal is LOW, the processor writes into the VL6845.                                                                                                                                         |
| <del>CS</del>        | 25            | Chip Select             | Input that, when HIGH, deselects VL6845; when this signal is LOW, the VL6845 is selected. This signal is typically connected to the system address bus either directly or through an address decoder.                                                                                       |
| RS                   | 24            | Register Select         | Input that, when LOW, selects the Address Register of the VL6845 for a write<br>operation. When this signal is HIGH, an internal register of the VL6845 specified<br>by the contents of the address register is selected.                                                                   |
| D0-D7                | 26-33         | Data Bus                | Eight bidirectional data lines that are used for transferring data between the<br>microprocessor and the VL6845. These lines are normally high-impedance,<br>except during read and write cycles when the chip is selected.                                                                 |
| Video Mem            | ory Characte  | er Generator Interf     | ace                                                                                                                                                                                                                                                                                         |
| CC0/MA0-<br>CC5/MA13 | 4-17          | Video Memory<br>Address | Active-HIGH output signals that are used to address the video display memory<br>in binary addressing mode. These memory addresses are generated in a binary<br>sequential fashion.                                                                                                          |
|                      |               |                         | In row/column addressing mode, MA0-MA7 function as column addresses, and MA8-MA13 function as row addresses.                                                                                                                                                                                |
| RA0-<br>RA4/STB      | 34-38         | Raster Address          | Active-HIGH output signals that are used as address lines to the external character generator ROM.<br>In the transparent addressing mode, RA4 functions as an active-HIGH output strobe.                                                                                                    |
| HSYNC                | 39            | Horizontal Sync         | Active-HIGH, TTL-compatible output signal that is used to determine the horizontal position of the displayed text. HSYNC may drive a CRT monitor directly or may be used for composite video generation. Position and width of HSYNC width are fully programmable.                          |
| VSYNC                | 40            | Vertical Sync           | Active-HIGH, TTL-compatible output signal that is used to determine the vertical position of the displayed text. VSYNC may be used to drive a CRT monitor directly or may be used for composite video generation. VSYNC position is fully programmable.                                     |
| DISPLAY              | 18            | Display Enable          | TTL-compatible output that, when HIGH, indicates that the VL6845 is generating active display information. The number of horizontal displayed characters and the number of vertical displayed rows are both fully programmable and together are used to generate the Display Enable signal. |
| CURSOR               | 19            | Cursor                  | TTL-compatible output that when HIGH, indicates a valid cursor address to the external video processing logic.                                                                                                                                                                              |
| LPSTB                | 3             | Light Pen Strobe        | HIGH-impedance, edge-sensitive input signal that latches the current refresh<br>address into the light pen register. Latching occurs on the LOW-to-HIGH<br>transition edge.                                                                                                                 |
| CCLK                 | 21            | Character Clock         | Input signals derived from the external dot clock, that is used as the time base for all internal count and control functions.                                                                                                                                                              |
| RES                  | 2             | Reset                   | Input signal that when LOW, resets all internal counters. All scan and video outputs are LOW and all control registers are unaffected. RES can be used to synchronize display frame timing with the line frequency.                                                                         |
| VCC                  | 20            | Supply Voltage          | 5 V supply                                                                                                                                                                                                                                                                                  |
| GND                  | 1             | Ground                  | Supply and signal ground                                                                                                                                                                                                                                                                    |

# VL6845 FAMILY FUNCTIONAL DESCRIPTION

The VL6845 CRT Controller (CRTC) consists of programmable horizontal and vertical timing generators, programmable linear address registers, programmable cursor logic, a light pen capture register and control circuitry for interface to a processor bus.

All CRTC timing is derived from the character clock (CCLK), which is usually the output of an external dot rate counter. Coincidence circuits internal to the chip continuously compare counter contents to the programmed register file (R0-R17) for generation of Horizontal Sync, Vertical Sync, Display Enable, Cursor and other signals required to interface to a CRT display.

The linear address generator is also driven by the CCLK and locates the positions of characters in memory with respect to their positions on the screen. Fourteen address lines, MA0-MA13 are available for addressing up to 16K characters of memory. The CRTC addresses the memory in the binary sequential fashion. Using the start address register, hardware scrolling through the 16K character memory is possible. The linear address generator continues to increment during the blanking period, so memory refresh can be performed during the blanking periods. The linear address generator repeats the same sequence of addresses for each scan line of a character row. Although the linear address generator continues to

increment during the horizontal and blanking periods, the correct address for the first displayed character or row is always maintained.

The Cursor logic determines the cursor location, size and blink rate on the screen.

The Light Pen Strobe latches the current contents of the address counter into the light pen register on LOW-to-HIGH transition.

#### INTERLACE MODE SELECTION

In the normal sync mode (noninterlace), only one field is available, as shown in Figure 1a. Each scan line is refreshed at the VSYNC frequency (50 or 60 Hz).

Two interlace modes are available as shown in Figure 1b and Figure 1c. The frame time is divided between even and odd alternating fields. The horizontal and vertical timing relationship (VSYNC delayed by one-half scan line time) results in the displacement of scan lines in the odd field with respect to the even field.

In the interlace sync mode, the same information is painted in both fields, as shown in Figure 1b. This is a useful mode for filling in a character to enhance readability.

In the interlace sync and video mode, as shown in Figure 1c, alternating lines of the character are displayed in the even field and the odd field. This effectively doubles the given band width of the CRT monitor.

Care must be taken when using either interlace mode to avoid an apparent flicker effect. This flicker effect is due to the doubling of the refresh time for all scan lines since each field is displayed alternately and may be minimized with proper monitor design i.e., longer persistence phosphors.

#### VL6845R/VL68C45R REGISTER FILE DESCRIPTIONS

The 19 registers of the CRTC may be accessed through the data bus. Only two memory locations are required, as one location is used as a pointer to address one of the remaining 18 registers. These 18 registers control horizontal timing, vertical timing, interlace operation and row address operation. They also define the cursor, cursor address, start address and light pen register. The register addresses and sizes are shown in Table 1.

**ADDRESS REGISTER (AR)** 

The Address Register is a 5-bit writeonly register used as an "indirect" or "pointer" register. It contains the address of one of the other 18 registers. When both RS and  $\overline{CS}$  are LOW, the Address Register is selected. When  $\overline{CS}$  is LOW and RS is HIGH, the register pointed to by the address register is selected.

#### FIGURE 1a. NORMAL SYNC



## FIGURE 1b. INTERLACE SYNC





#### FIGURE 1c. INTERLACE SYNC AND VIDEO





#### VL6845R/VL68C45R REGISTER FILE DESCRIPTIONS (Cont.)

#### HORIZONTAL TOTAL REGISTER (R0)

This 8-bit write-only register determines the horizontal sync (HSYNC) frequency by defining the HSYNC period in character times. It is the total of the displayed characters plus the non-displayed character times (retrace) minus one.

#### HORIZONTAL DISPLAYED REGISTER (R1)

This 8-bit write-only register determines the number of displayed characters per line. Any 8-bit number may be programmed as long as the contents of R0 are greater than the contents of R1.

#### HORIZONTAL SYNC POSITION REGISTER (R2)

This 8-bit write-only register controls the HSYNC position, which defines the horizontal sync delay (front porch) and the horizontal scan delay (back porch). When the programmed value of this register is increased, the display on the CRT screen is shifted to the left. When the programmed value is decreased, the display is shifted to the right. Any 8-bit number may be programmed as long as the sum of the contents of R2 and R3 is less than the contents of R0. The contents of R2 must be greater than R1.

#### SYNC WIDTH REGISTER (R3)

This 8-bit write-only register determines the width of the HSYNC pulse. The vertical sync pulse width is fixed at 16 scan-line times. HSYNC pulse width may be programmed from 1 to 15 character clock periods, thus allowing compatibility with the HSYNC pulse width specifications of many different monitors. If zero is written into this register, no horizontal sync is provided.

HORIZONTAL TIMING SUMMARY The difference between R0 and R1 is the horizontal blanking interval. This interval in the horizontal scan period allows the beam to return (retrace) to the left side of the screen. The retrace time is determined by the monitor horizontal scan components. Retrace time is less than the horizontal blanking interval.

A good rule of thumb is to make the horizontal blanking about 20% of the total horizontal scanning period for a CRT. In inexpensive TV receivers the beam over-scans the display screen so that aging of parts does not result in underscanning. Because of this, the retrace time should be about one-third the horizontal scanning period. The horizontal sync delay is typically programmed with a 1:2:2 ratio.

#### VERTICAL TOTAL REGISTER (R4) AND VERTICAL TOTAL ADJUST REGISTER (R5)

The vertical sync (VSYNC) frequency is determined by both R4 and R5. The

| IAD |    | I. VI | -004 | ion/  | LOC  | 5040 |          | NAL NEGISTEN ASS      | GINWENTS  |      |       |   |   |    |     |        |      |        |    |
|-----|----|-------|------|-------|------|------|----------|-----------------------|-----------|------|-------|---|---|----|-----|--------|------|--------|----|
| CS  | BS | A     | ddre | ss Re | gist | er   | Register | Register File         | Program   | Read | Write |   |   | Nu | mbe | r of E | lits |        |    |
| ••• |    | 4     | 3    | 2     | 1    | 0    | ] #      |                       | Unit      |      |       | 7 | 6 | 5  | 4   | 3      | 2    | 1      | 0  |
| 1   | X  | X     | Х    | X     | X    | X    | X        |                       | _         |      |       |   |   |    |     |        |      |        |    |
| 0   | 0  | Х     | Х    | X     | X    | X    | AR       | Address Register      | —         | No   | Yes   |   |   |    |     |        |      |        |    |
| 0   | 1  | 0     | .0   | 0     | 0    | 0    | RO       | Horizontal Total      | Char.     | No   | Yes   |   |   | 1  |     |        |      |        |    |
| 0   | 1  | 0     | 0    | 0     | 0    | 1    | R1 .     | Horizontal Displayed  | Char.     | No   | Yes   |   |   |    |     |        |      |        |    |
| 0   | 1  | 0     | 0    | Q     | 1    | 0    | R2       | H. Sync Position      | Char.     | No   | Yes   |   |   |    |     |        |      |        |    |
| 0   | 1  | 0     | 0    | 0     | 1    | 1    | R3       | Sync Width            |           | No   | Yes   |   |   | 1  |     | н      | н    | Н      | н  |
| 0   | 1  | 0     | 0    | 1     | 0    | 0    | R4       | Vertical Total        | Char. Row | No   | Yes   |   |   |    |     |        |      |        |    |
| 0   | 1  | 0     | 0    | 1     | 0    | Ì    | R5       | V. Total Adjust       | Scan Line | No   | Yes   |   |   |    |     |        |      |        |    |
| 0   | 1  | 0     | 0    | 1     | 1    | 0    | R6       | Vertical Displayed    | Char. Row | No   | Yes   |   |   |    |     |        |      |        |    |
| 0   | 1  | 0     | 0    | 1     | 1    | 1    | R7       | V. Sync Position      | Char. Row | No   | Yes   |   |   |    |     |        |      |        |    |
| 0   | 1  | 0     | 0    | 0     | 1    | 1    | R3       | Sync Width            |           | No   | Yes   |   |   |    |     |        |      | 1      | I  |
| 0   | 1  | 0     | 1    | 0     | 0    | 1    | R9       | Max Scan Line Address | Scan Line | No   | Yes   |   |   |    |     |        |      |        |    |
| 0   | 1  | 0     | 1    | 0     | 1    | 0    | R10      | Cursor Start          | Scan Line | No   | Yes   |   | В | Р  |     |        | (1   | Note 2 | 2) |
| 0   | 1  | 0     | 1    | 0     | 1    | 1    | R11      | Cursor End            | Scan Line | No   | Yes   |   |   |    |     |        |      |        |    |
| 0   | 1  | 0     | 1    | 1     | 0    | 0    | R12      | Start Address (H)     | ·         | No   | Yes   | 0 | 0 |    |     |        |      |        |    |
| 0   | 1  | 0     | 1    | 1     | 0.   | 1    | R13      | Start Address (L)     | —         | No   | Yes   |   |   |    |     |        |      |        |    |
| 0   | 1  | 0     | 1    | 1     | 1    | 0    | R14      | Cursor (H)            |           | Yes  | Yes   | 0 | 0 |    |     |        |      |        |    |
| 0   | 1  | 0     | 1    | 1     | 1    | 1    | R15      | Cursor (L)            |           | Yes  | Yes   |   |   |    |     |        |      |        |    |
| 0   | 1  | 1     | 0    | 0     | 0    | 0    | R16      | Light Pen (H)         | -         | Yes  | No    | 0 | 0 |    |     |        |      |        |    |
| 0   | 1  | 1     | 0    | 0     | 0    | 1    | R17      | Light Pen (L)         |           | Yes  | No    |   |   |    |     |        |      |        |    |

# TABLE 1: VL6845R/VL68C45R INTERNAL REGISTER ASSIGNMENTS

#### Notes:

1. The interlace bits are described in Table 2.

2. Bit 5 of the cursor start raster register is used for blink period, control, and bit 6 is used to select blink or no-blink.

3. Registers R4, R6 and R7 in the VL68C45R are eight bits wide, instead of seven, for compatibility with the Motorola 6845R1.

#### VL6845R/VL68C45R REGISTER FILE DESCRIPTIONS (Cont.)

calculated number of character row times is usually an integer plus a fraction to get exactly a 50 Hz or 60 Hz vertical refresh rate. The integer number of character row times minus one is programmed into the 7-bit write-only vertical total register (R4). The fraction of character line times is programmed into the 5-bit write-only vertical total adjust register (R5) as the number of scan lines required.

#### VERTICAL DISPLAYED REGISTER (R6)

This 7-bit write-only register specifies the number of character rows displayed on the CRT screen, and is programmed in character row times. Any number smaller than contents R\$ may be programmed into R6.

#### VERTICAL SYNC POSITION REGISTER (R7)

This 7-bit write-only register controls the position of vertical sync with respect to the reference. It is programmed in character row times. When programmed value of this register is increased, the display position of the CRT screen is shifted up. When the programmed value is decreased, the display position is shifted down. Any number equal to or less than the contents of R4 and greater than or equal to the R6 may be used.

#### INTERLACE MODE AND SKEW REGISTER (R8)

The VL6845R only allows control of the interlace modes as programmed by the low-order two bits of this write-only register. Table 2 shows the interlace modes available to the user. These modes are selected using the two low order bits of this 6-bit write-only register.

#### TABLE 2: INTERLACE MODE REGISTER

| Bit 1 | Bit 2 | Mode                          |
|-------|-------|-------------------------------|
| 0     | 0     | Normal Sync Mode              |
| 1     | 0     | (Non-interlace)               |
| 0     | 1     | Interlace Sync Mode           |
| 1     | 1     | Interlace Sync and Video Mode |

#### INTERLACE MODE AND SKEW REGISTER (R8) (Cont.)

There are restrictions on the programming of the VL6845R/VL68C45R registers for interlace operation:

- 1. The Horizontal Total Register (R0) value must be odd (i.e., and even number of character times).
- For interlace sync and video mode only, the Maximum Scanline Address Register (R9) value must be odd (i.e., an even number of scan lines).
- For interlace sync and video mode only, the number (Nvd) programmed into the Vertical Display Register (R6) must be one-half the actual number required. The evennumbered scan lines are displayed in the even field and the oddnumbered scan lines are displayed in the odd field.
- 4. For interlace sync and video mode only, the Cursor Start Register (R10) and Cursor End Register (R11) must both be even or odd, depending on which field the cursor is to be displayed in. A full block cursor will be displayed in both in both the even and the odd field when the Cursor End Register (R11) is programmed to a value greater than the value in the Maximum Scan Line Address Register (R9).

#### MAXIMUM SCAN LINE ADDRESS REGISTER (R9)

This 5-bit write-only register determines the number of scan lines per character row, including the spacing, thus controlling operation of the row address counter. The programmed value is a maximum address and is one less than the number of scan lines.

## CURSOR CONTROL REGISTERS

#### CURSOR START REGISTER (R10) AND CURSOR END REGISTER (R11)

These registers allow a cursor of up to 32 lines in height to be placed on any scan line of the character block. Register R10 is a 7-bit write-only register used to define the start scan line and the cursor blink rate. Bits 5 and 6 of the Cursor Start Address Register control the cursor operation as shown in table 3. Non-display, display, and two blink modes (16 times or 32 times the field period) are available. Register R11 is a 5-bit write-only register that defines the last scan cursor.

# TABLE 3: CURSOR START REGISTER

| Bit 6 | Bit 5 | Cursor Display Mode    |
|-------|-------|------------------------|
| 0     | 0     | Non-blink              |
| 0     | 1     | Cursor Non-display     |
| 1     | 0     | Blink, 1/16 field rate |
| 1     | 1     | Blink, 1/32 field rate |

When an external blink feature on characters is required, it may be necessary to perform cursor blink externally so that both blink rates are synchronized. Note that an invert/ non-invert cursor is easily implemented by programming the CRT for a blinking cursor and externally inverting the video signal with an exclusive-OR gate.

**CURSOR REGISTER (R14-H, R15-L)** This 14-bit read/write register pair is programmed to position the cursor anywhere in the refresh RAM area, thus allowing hardware paging and scrolling through memory without loss of the original cursor position. It consists of an 8-bit low-order (MA0-MA7) register and a 6-bit high-order (MA8-MA13) register.

# START ADDRESS AND LIGHT PEN REGISTERS

#### START ADDRESS REGISTER (R12-H, R13-L)

This 14-bit write-only register pair controls the first address output by the CRTC after vertical blanking. It consists of an 8-bit low-order (MA0-MA7) register and a 6-bit high-order (MA8-MA13) register. The start address register determines which portion of the refresh RAM is displayed on the CRT screen. Hardware scrolling by character or page may be accomplished by modifying the contents of this register.

LIGHT PEN REGISTER (R16-H, R17-L)

This 14-bit read-only register pair captures the refresh address output by the CRTC on the positive edge of a pulse input to the LPSTB pin. It consists of an 8-bit low-order (MA0-MA7) register and a 6-bit high-order (MA8-MA13) register. Since the light pen pulse is asynchronous with respect to refresh address timing, an internal synchronizer is designed into the CRTC. Due to delays in this circuit, the value of R16 and R17 will need to be corrected in software. (See the bus timing diagram in the Timing Characteristics section.)

# VL68C45S REGISTER FILE DESCRIPTIONS

#### TABLE 4: VL68C45S INTERNAL REGISTER ASSIGNMENTS, Note 1

| <del>CS</del> | RS |   | Ac<br>Re | ldre<br>gis | ess<br>ter |   | Register<br># | Register Name                | ne Program Unit READ WRITE Data Bit          |     |   |     |     |     |     |     |     |     |     |
|---------------|----|---|----------|-------------|------------|---|---------------|------------------------------|----------------------------------------------|-----|---|-----|-----|-----|-----|-----|-----|-----|-----|
|               |    | 4 | 3        | 2           | 1          | 0 |               |                              |                                              |     |   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| 1             | ×  | × | x        | ×           | x          | x |               | -                            | -                                            | -   | - |     |     |     |     |     |     |     |     |
| 0             | 0  | x | x        | x           | x          | x | AR            | Address Register             | _                                            | ×   | 0 |     |     |     |     |     |     |     |     |
| 0             | 1  | 0 | 0        | 0           | 0          | 0 | R0            | Horizontal Total*            | Character                                    | ×   | 0 |     |     |     |     |     |     |     |     |
| 0             | 1  | 0 | 0        | 0           | 0          | 1 | R1            | Horizontal<br>Displayed      | Character                                    | ×   | 0 |     |     |     |     |     |     |     |     |
| 0             | 1  | 0 | 0        | 0           | 1          | 0 | R2            | Horizontal Sync*<br>Position | Character                                    | . × | 0 |     |     |     |     |     |     |     |     |
| 0             | 1  | 0 | 0        | 0           | 1          | 1 | R3            | Sync Width                   | Vertical-Raster,<br>Horizontal-<br>Character | ×   | 0 | wv3 | wv2 | wv1 | wv0 | wh3 | wh2 | wh1 | wh0 |
| 0             | 1  | 0 | 0        | 1           | 0          | 0 | R4            | Vertical Total*              | Line                                         | ×   | 0 |     |     |     |     |     |     |     |     |
| 0             | 1  | 0 | 0        | 1           | 0          | 1 | - R5          | Vertical Total Adjust        | Raster                                       | ×   | 0 |     |     |     |     |     |     |     |     |
| 0             | 1  | 0 | 0        | 1           | 1          | 0 | R6            | Vertical Displayed           | Line                                         | ×   | 0 |     |     |     |     |     |     |     |     |
| 0             | 1  | Ö | 0        | 1           | 1          | 1 | R7            | Vertical Sync*<br>Position   | Line                                         | ×   | 0 |     |     |     |     |     |     |     |     |
| 0             | 1  | 0 | 1        | 0           | 0          | 0 | R8            | Interlace & Skew             |                                              | ×   | 0 | C1  | CO  | D1  | D0  |     |     | v   | S   |
| 0             | 1  | 0 | 1        | 0           | 0          | 1 | R9            | Maximum Raster<br>Address    | Raster                                       | ×   | 0 |     |     |     |     |     |     |     |     |
| 0             | 1  | 0 | 1        | 0           | 1          | 0 | R10           | Cursor Start Raster          | Raster                                       | ×   | 0 |     | в   | Р   |     |     |     |     |     |
| 0             | 1  | 0 | 1        | 0           | 1          | 1 | R11           | Cursor End Raster            | Raster                                       | ×   | 0 |     |     |     |     |     |     |     |     |
| 0             | 1  | 0 | 1        | 1           | 0          | 0 | R12           | Start Address (H)            | -                                            | 0   | 0 |     |     |     |     |     |     |     |     |
| 0             | 1  | 0 | 1        | 1           | 0          | 1 | R13           | Start Address (L)            | -                                            | 0   | 0 |     |     |     |     |     |     |     |     |
| 0             | 1  | 0 | 1        | 1           | 1          | 0 | R14           | Cursor (H)                   | -                                            | 0   | 0 |     |     |     |     |     |     |     |     |
| 0             | 1  | 0 | 1        | 1           | 1          | 1 | R15           | Cursor (L)                   | -                                            | 0   | 0 |     |     |     |     |     |     |     |     |
| 0             | 1  | 1 | 0        | 0           | 0          | 0 | R16           | Light Pen (H)                | -                                            | 0   | × |     |     |     |     |     |     |     |     |
| 0             | 1  | 1 | 0        | 0           | 0          | 1 | R17           | Light Pen (L)                | -                                            | 0   | × |     |     |     |     |     |     |     |     |

Note:

1.  $\circ = yes; \times = no$ 

#### VL68C45S REGISTER FILE DESCRIPTIONS (Cont.) ADDRESS REGISTER (AR)

This is a 5-bit register that is used to select 18 internal control registers (R0-R17). Its contents are the address of one of 18 internal control registers. Programming the data from 18 to 31 produces no results. Access to R0-R17 requires writing the address of the corresponding control register into this register. When RS and CS are LOW, the address is selected.

#### **HORIZONTAL TOTAL REGISTER (R0)**

This 8-bit register is used to program the total number of horizontal characters per line, including the retrace period. The data value should be programmed according to the specification of the CRT. When M is the total number of characters, (M-1) must be programmed into this register. When programming for interlace mode, M must be even.

#### HORIZONTAL DISPLAYED REGISTER (R1)

This 8-bit register is used to program the number of horizontal displayed characters per line. Any 8-bit number that is smaller than that of horizontal total register contents can be programmed.

#### HORIZONTAL SYNC POSITION REGISTER (R2)

This 8-bit register is used to program horizontal sync position as multiples of the character clock period. Any 8-bit number that is lower than the horizontal total register contents can be programmed. When H is the character number of the horizontal sync position, (H-1) must be programmed into this register. When the programmed value of this register is increased, the display position on the CRT screen is shifted to the left. When the programmed value is decreased, the position is shifted to the right. Therefore, the optimum horizontal position can be determined by this value.

#### SYNC WIDTH REGISTER (R3)

This 8-bit register is used to program the horizontal sync (HS) pulse width and the vertical sync (VS) pulse width. The horizontal sync pulse width is programmed in the lower four-bits as multiples of the character clock period (see Table 5); a zero cannot be programmed. The vertical sync pulse width is programmed in the higher four bits as multiples of the raster period (see Table 6). When zeroes are programmed in the higher four bits, a 16-raster period is specified.

#### **VERTICAL TOTAL REGISTER (R4)**

This 7-bit register is used to program the total number of lines per frame, including vertical retrace period. The data and its value should be programmed according to the specification of the CRTC. When N is the total number of lines, (N-1) must be programmed into this register.

#### VERTICAL TOTAL ADJUST REGISTER (R5)

This 5-bit register is used to program the optimum number to adjust the total number of rasters per field. This register enables more precise control of the deflection frequency.

# VERTICAL DISPLAYED REGISTER (R6)

This 7-bit register is used to program the number of displayed character rows on the CRT screen. Any 7-bit number that is smaller than that of vertical total register contents can be programmed.

#### VERTICAL SYNC POSITION REGISTER (R7)

This 7-bit register is used to program the vertical sync position on the screen as multiples of the horizontal character line period. Any number that is equal to or less than the vertical total register content can be programmed. When V is the character number of vertical sync position, (V-1) must be programmed to this register. When programmed value of this register is increased, the display position is shifted up. When the programmed value is decreased, the position is shifted down. Therefore, the optimum vertical position may be determined by this value.

#### INTERLACE AND SKEW REGISTER (R8)

This register is used to program raster scan mode and skew (delay) of the Cursor signal and Display Enable signals.

#### INTERLACE MODE PROGRAM BITS (V,S)

Raster scan mode is programmed (see Table 7) by the V and S bits of R8. In the non-interlace mode, duplicate scanning is done of the rasters of even number field and odd number field. In the interlace sync mode, the rasters of the odd number field are scanned in the middle of the even number field. The same character pattern is then displayed in two fields. In the interlace sync and video mode, the raster scan method is the same as in the interlace sync mode, but it is controlled to display different character patterns in two fields.

#### Note:

1. The registers marked \*:

(written value) = (specified value) -1

- 2. Written value of R9:
  - a) Non-interlace mode and Interlace Sync Mode (written value Nr) = (specified value) 1
  - b) Interlace sync and video mode: (Written value Nr) = (specified value) -2
- 3. CO and C1 specify skew of CURSOR output signal.

DO and D1 specify skew of Display Enable output signal. When S is one, V specifies video mode. S specifies the Interlace sync mode.

- 4. B specifies cursor blink.
- P specifies the cursor blink period.
- 5. wv0~wv3 specify the pulse width of the vertical sync signal. wh0~wh3 specify the pulse width of the horizontal sync signal.
- 6. RO is normally programmed to be an odd number in interlace mode.
- 7. 0 = Yes, X = No

# VL68C45S

# REGISTER FILE DESCRIPTIONS (Cont.)

# TABLE 5: PULSE WIDTH OF HORIZONTAL SYNC SIGNAL

| VSV   | V/HSW F  | Register | (R3)      | HSW Pulse Width                  |
|-------|----------|----------|-----------|----------------------------------|
| Bit 3 | Bit 2    | Bit 1    | Bit 0     | (multiples of char clock period) |
| 0     | 0        | 0        | 0         | Not Allowed                      |
| 0     | 0        | 0        | 1         | 1                                |
| 0     | 0        | 1        | 0         | 2                                |
| 0     | 0        | 1        | 1         | 3                                |
| 0     | 1        | 0        | 0         | 4                                |
| 0     | 1        | 0        | 1         | 5                                |
| 0     | 1        | 1        | 0         | 6                                |
| 0     | 1        | 1        | <u></u> 1 | 7                                |
| 1     | 0        | 0        | 0         | 8                                |
| 1     | 0        | 0        | 1         | 9                                |
| 1     | 0        | 1        | 0         | 10                               |
| 1     | 0        | 1        | 1         | 11                               |
| 1     | 1        | 0        | 0         | 12                               |
| 1     | <u> </u> | 0        | 1         | 13                               |
| 1     | 1        | 1        | 0         | 14                               |
| 1     | 1        | 1        | 1         | 15                               |

## TABLE 6: PULSE WIDTH OF VERTICAL SYNC SIGNAL

| VSW/I | ISW Re | gister (F | 13)   | VSW Pulse Width              |  |  |
|-------|--------|-----------|-------|------------------------------|--|--|
| Bit 7 | Bit 6  | Bit 5     | Bit 4 | (multiples of raster period) |  |  |
| 0     | 0      | -0        | . 0   | 16                           |  |  |
| 0     | 0      | 0         | 1     | · . 1                        |  |  |
| 0     | 0      | 1         | 0     | 2                            |  |  |
| 0     | 0      | 1         | 1     | 3                            |  |  |
| 0     | .1     | 0         | 0     | 4                            |  |  |
| 0     | 1      | 0         | 1     | 5                            |  |  |
| 0     | 1 F    | 1         | 0     | 6                            |  |  |
| 0     | 1      | 1         | 1     | 7                            |  |  |
| 1     | 0      | 0         | 0     | 8                            |  |  |
| 1     | 0      | 0         | 1     | 9                            |  |  |
| 1     | 0      | 1         | 0     | 10                           |  |  |
| 1     | 0      | 1         | 1     | 11                           |  |  |
| 1     | 1      | 0         | 0     | 12                           |  |  |
| 1     | 1      | 0         | 1     | 13                           |  |  |
| 1     | 1      | 1         | 0     | 14                           |  |  |
| 1     | 1      | 1         | 1     | 15                           |  |  |

#### TABLE 7: INTERLACE MODE BITS (BITS 1 AND 0 of R8)

| V<br>Bit 1 | S<br>Bit 2 | Mode                             |
|------------|------------|----------------------------------|
| 0          | 0          | Normal Sync Mode                 |
| 1          | 0          | (Non-interlace)                  |
| 0          | 1          | Interlace Sync Mode              |
| 1          | 1          | Interlace Sync and<br>Video Mode |

# SKEW PROGRAM BITS (C1,C0,D1,D0)

These bits are used to program the skew (delay) of the Cursor and Display Enable signals.

Skew of these two kinds of signals is programmed separately. The skew function is used to provide an on-chip delay for the output timing of the of the Cursor and Display Enable "gnals to provide the time required to access refresh memory, character generator or pattern generator, and to ensure that they are in phase with the serial video signal.

#### TABLE 8: DISPLAY ENABLE SKEW BIT (BITS 5 AND 4 OF R8)

| D1<br>Bit 5 | D0<br>Bit 4 | Display Enable Signal |
|-------------|-------------|-----------------------|
| 0           | 0           | Non-Skew              |
| 0           | 1           | One-character Skew    |
| 1           | 0           | Two-character Skew    |
| 1           | 1           | Non-output            |

#### TABLE 9: CURSOR SKEW BITS (BITS 7 & 6 OF R8)

| C1<br>Bit 7 | C0<br>Bit 6 | Display Skew       |
|-------------|-------------|--------------------|
| 0           | 0           | Non-Skew           |
| 0           | 1           | One-character Skew |
| 1           | 0           | Two-character Skew |
| 1           | 1           | Non-output         |

#### VL68C45S REGISTER FILE **DESCRIPTIONS** (Cont.)

#### MAXIMUM RASTER ADDRESS **REGISTER (R9)**

This 5-bit register is used to program the Maximum Raster Address. This register defines total number of rasters per character, including space.

This register is programmed as follows:

- 1. Non-Interlace Mode. Interlace Sync Mode: When the total number of rasters is RN, (RN-1) must be programmed.
- 2. Interlace Sync and Video Mode: When total number of rasters is RN, (RN-2) must be programmed.

The total number of rasters in noninterlace mode, interlace svnc mode and interlace sync and video mode is defined as follows in Table 10.

#### TABLE 10: **RASTER COUNT IN** INTERLACE AND NON-INTERLACE MODES

| 0 | Total number of rasters 5                       |
|---|-------------------------------------------------|
| 1 | Programmed value Nr = 4                         |
| 2 | (The same as displayed total number of rasters) |

3.

# Raster Address

4

#### INTERLACE SYNC MODE

| 0 To | otal number of rasters 5                                             |
|------|----------------------------------------------------------------------|
| 0    | programmed value<br>Nr = 4                                           |
| 11   | In the interlace sync mode, total number of                          |
| 2    | rasters in both the<br>even and odd fields is<br>ten. On programming |
| 32   | the half of it is defined<br>as total number of                      |
| 43   | rasters.                                                             |

\_\_\_\_4

Raster Address

#### INTERLACE SYNC AND VIDEO MODE

\_\_\_\_ Total Number of Rasters 5 0 ----1 Programmed Value Nr = 3(Total number of 2 rasters displayed in the even field and the 4\_ odd field) .....

#### Raster Address

#### Note:

1. In the interlace mode, pulse width is changed + 1/2 raster time when vertical sync signal extends over two fields.

#### CURSOR START RASTER **REGISTER (R10)**

This 7-bit register is used to program the cursor start raster address and the cursor display mode. The lower five bits program the raster address and the higher two bits program the display mode (see table 11).

#### TABLE 11: CURSOR DISPLAY MODE (BITS 6 AND 5 OF R10)

| B<br>Bit 6 | P<br>Bit 5 | Cursor Display Mode    |
|------------|------------|------------------------|
| 0          | 0          | Non-Blink              |
| 0          | , 1        | Cursor Non-Display     |
| 1          | 0          | Blink, 1/16 Field Rate |
| 1          | 1          | Blink, 1/32 Field Rate |

Note:

5

The blink sequence is follows:

| Light            | Dark            |
|------------------|-----------------|
| (16 x or 32 x th | e field period) |

#### **CURSOR END RASTER REGISTER (R11)**

This register is used to program the cursor end raster address. START ADDRESS REGISTER

# (R12, R13)

This register pair is used to program the first address of refresh memory read out. Paging and scrolling are easily performed using this register. This register can be read but the higher 2-bits of R12 are always zero.

#### **CURSOR REGISTER (R14, R15)**

These two read/write registers store the cursor location. The higher 2 bits of R14 are zero.

## LIGHT PEN REGISTER (R16,R17)

These read-only registers are used to capture the detection address of the light pen. The higher 2 bits of R16 are always zero. The value of R16 and R17 needs to be corrected by software because there is a time delay from the address output by the CRTC to the signal input to its LPSTB pin that the light pen detects.

#### CONSIDERATIONS IN UPDATING REGISTERS

The value programmed into the internal registers directly controls the CRT. Consequently, the display may flicker on the screen when the contents of the registers are changed from the bus side asynchronously with display operation.

#### **RESTRICTIONS ON PROGRAMMING INTERNAL** REGISTERS

- 1.  $0 \leq Nhd \leq Nht + 1 \leq 256$
- 2.  $0 \leq Nvd \leq Nvt + 1 \leq 128$
- 3.  $0 \leq Nhsp \leq Nht$
- 4.  $0 \leq Nvsp \leq Nvt$ , Note 1
- 5.  $0 \leq \text{NCSTART} \leq \text{NCEND} \leq \text{Nr}$ (non-interlace, interlace sync mode) 0,NCSTART < NCEND < Nr + 1 (interlace sync and video mode)
- 2 ≤ Nr ≤ 30
- 7. 3 ≤ Nht (except non-interlace mode)
  - $5 \le Nht(non-interlace mode only)$

#### UPDATING THE CURSOR REGISTER

Writing into this register at frequent intervals for moving the cursor should be performed during horizontal and vertical retrace periods.

#### UPDATING THE START ADDRESS REGISTER

Writing into the start address register at frequent intervals for scrolling and paging should be performed during horizontal and vertical display periods.

It is desirable to avoid programming any registers besides the cursor and Start Address Register during display operations.

## VL6845E **REGISTER FILE DESCRIPTIONS**

## TABLE 12: VL6845E INTERNAL REGISTER ASSIGNMENT

|    |    | A | ddre | ss Re | egist | er | Register |                             | 99999997 - Maria Andrew 1997 - Maria Andrew 1997 - Andr<br>1 |        |        |    |    | R  | egis | ter E | Bit |     |    |
|----|----|---|------|-------|-------|----|----------|-----------------------------|----------------------------------------------------------------------------------------------------------------------|--------|--------|----|----|----|------|-------|-----|-----|----|
| CS | RS | 4 | 3    | 2     | 1     | 0  | Number   | Register Name               | Stored Info.                                                                                                         |        | WR     | 7  | 6  | 5  | 4    | 3     | 2   | 1   | 0  |
| 1  |    | - | -    | -     | -     | -  | -        |                             |                                                                                                                      |        |        |    |    |    |      |       |     |     |    |
| 0  | 0  | - | -    | -     | -     | -  |          | Address Register            | Register Number                                                                                                      |        | V      |    |    |    | A4   | A3    | A2  | A1  | A0 |
| 0  | 0  | - |      | -     | -     | -  | -        | Status Register             |                                                                                                                      | $\vee$ |        | U  | L  | ٧  |      |       |     |     |    |
| 0  | 1  | 0 | 0    | 0     | 0     | 0  | R0       | Horizontal Total            | # Character-1                                                                                                        |        | $\vee$ |    |    |    |      |       |     |     |    |
| 0  | 1  | 0 | 0    | 0     | 0     | 1  | R1       | Horizontal Displayed        | # Character                                                                                                          |        | $\vee$ |    |    |    |      |       |     |     |    |
| 0  | 1  | 0 | 0    | 0     | 1     | 0  | R2       | Horizontal Sync<br>Position | # Character                                                                                                          |        | V      |    |    |    |      |       |     |     |    |
| 0  | 1  | 0 | 0    | 0     | 1     | 1  | R3       | VSYNC, HSYNC<br>Widths      | # Scan Lines and #<br>Character TImes                                                                                |        | $\vee$ | vз | V2 | V1 | vo   | нз    | H2  | H1  | но |
| 0  | 1  | 0 | 0    | 1     | 0     | 0  | R4       | Vertical Total              | # Character Row -1                                                                                                   |        | $\vee$ |    |    |    |      |       |     | . 1 |    |
| 0  | 1  | 0 | 0    | 1     | 0     | 1  | R5       | Vertical Total Adjust       | # Scan Lines                                                                                                         |        | $\vee$ |    |    |    |      |       |     |     |    |
| 0  | 1  | 0 | 0    | 1     | 1     | 0  | R6       | Vertical Displayed          | # Character Rows                                                                                                     |        | $\vee$ | 1  |    |    |      |       |     |     |    |
| 0  | 1  | 0 | 0    | 1     | 1     | 1  | R7       | Vertical Sync Position      | # Character Rows                                                                                                     |        | $\vee$ |    |    |    |      |       |     |     |    |
| 0  | 1  | 0 | 1    | 0     | 0     | 0  | R8       | Mode Control                |                                                                                                                      |        | $\vee$ | U1 | U0 | С  | D    | Т     | RC  | 11  | 10 |
| 0  | 1  | 0 | 1    | 0     | 0     | 1  | R9       | Scan Line                   | # Scan Lines -1                                                                                                      |        | $\vee$ |    |    |    |      |       |     |     |    |
| 0  | 1  | 0 | 1    | 0     | 1     | 0  | R10      | Cursor Start                | Scan Line No.                                                                                                        |        | $\vee$ |    | B1 | B0 |      |       |     |     |    |
| 0  | 1  | 0 | 1    | 0     | 1     | 1  | R11      | Cursor End                  | Scan Line Number                                                                                                     | Τ      | $\vee$ | -  |    |    |      |       |     |     |    |
| 0  | 1  | 0 | 1    | 1     | 0     | 0  | R12      | Display Start<br>Addr (H)   | Row                                                                                                                  |        | $\vee$ |    |    |    |      |       |     |     |    |
| 0  | 1  | 0 | 1    | 1     | 0     | 1  | R13      | Display Start<br>Addr (L)   | Column                                                                                                               |        | $\vee$ |    |    |    |      |       |     |     |    |
| 0  | 1  | 0 | 1    | 1     | 1     | 0  | R14      | Cursor Position (H)         | Row                                                                                                                  | $\vee$ | $\vee$ |    | -  |    |      |       |     |     |    |
| 0  | 1  | 0 | 1    | 1     | 1     | 1  | R15      | Cursor Position (L)         | Column                                                                                                               | $\vee$ | $\vee$ |    |    |    |      |       |     |     |    |
| 0  | 1  | 1 | 0    | 0     | 0     | 0  | R16      | Light Pen Register (H)      |                                                                                                                      | $\vee$ |        |    |    |    |      |       |     |     |    |
| 0  | 1. | 1 | 0    | 0     | 0     | 1  | R17      | Light Pen Register (L)      |                                                                                                                      | $\vee$ |        |    |    |    |      |       |     | ·   |    |
| 0  | 1  | 1 | 0    | 0     | 1     | 0  | R18      | Update Location (H)         |                                                                                                                      |        | $\vee$ |    |    |    |      |       |     |     |    |
| 0  | 1  | 1 | 0    | 0     | 1     | 1  | R19      | Update Location (L)         |                                                                                                                      |        | $\vee$ |    |    |    |      |       |     |     |    |
| 0  | 1  | 1 | 1    | 1     | 1     | 1  | R31      | Dummy Location              |                                                                                                                      |        |        |    |    |    |      |       |     |     |    |

Note: 1. designates unused bit. Reading this bit is always "0", except for R31, which does not drive the data bus at all, and for  $\overline{CS} =$  "1" which operates likewise.

# **VL6845E REGISTER FILE DESCRIPTIONS** (Cont.)

#### ADDRESS REGISTER

This 5-bit register is used as a "pointer" to direct VL6845E data transfers to and from the system MPU. Its contents are the number of the desired register (0-31). When RS is LOW, the address register may be loaded: when RS is HIGH, the register selected is the one whose identity is stored in this register.

#### STATUS REGISTER

This 3-bit register is used to monitor the status of the CRTC. It is only accessed in reading, while the Address Register is only accessed in writing. Both these registers are accessed with RS and CS LOW.



\*IF BITS 4-7 ARE ALL "0" THEN VSYNC WILL BE 16 SCAN LINES WIDE.

# HORIZONTAL TOTAL REGISTER (R0)

This 8-bit register contains the total of displayed and non-displayed characters, minus one, per horizontal line. The horizontal sync (HSYNC) frequency is thus determined by this register.

#### HORIZONTAL DISPLAYED **REGISTER (R1)**

This 8-bit register contains the number of displayed characters per horizontal line.

#### HORIZONTAL SYNC POSITON **REGISTER (R2)**

This 8-bit register contains the HSYNC position on the horizontal line, in terms of the character location number on the line. The position of HSYNC determines the left-to-right location of the displayed text on the video screen. In this way, the side margins are adiusted.

#### HORIZONTAL AND VERTICAL SYNC WIDTH REGISTER (R3)

This 8-bit register contains the widths of both HSYNC and VSYNC, as follows:



STROBE OCCURS.

Control of these parameters allow the VL6845E to be interfaced to a variety of CRT monitors, since the HSYNC and VSYNC timing signals may be accommodated without the use of external one shot timing.

#### VERTICAL TOTAL REGISTER (R4)

This 7-bit register contains the total number of character rows in a frame. minus one. This register, along with R5, determines the overall frame rate, which should be close to the line frequency to ensure flicker-free appearance. If the frame time is adjusted to be longer than the period of the line frequency RES may be used to provide absolute syncronism.

#### VERTICAL TOTAL ADJUST **REGISTER (R5)**

This 5-bit write-only register contains the number of additional scan lines needed to complete an entire frame scan and is intended as a fine adjustment for the video frame time.

#### VERTICAL DISPLAYED REGISTER (R6)

This 7-bit register contains the number of displayed character rows in each frame. In this way, the vertical size of the displayed text is determined.

#### VERTICAL SYNC POSITION **REGISTER (R7)**

This 7-bit register is used to select the character row time at which the VSYNC pulse is desired to occur and, thus, is used to position the displayed text in the vertical direction.

# VL6845E REGISTER FILE DESCRIPTIONS (Cont.)

# MODE CONTROL REGISTER (R8)

This register is used to select the operating modes of the VL6845E and is outlined as follows:



#### **SCAN LINE REGISTER (R9)**

This 5-bit register contains the number of scan lines per character row, including space minus one.

#### CURSOR START REGISTER (R10) AND CURSOR END REGISTER (R11) These 5-bit registers select the starting

and ending scan lines for the cursor. In addition, bits 5 and 6 of R10 are used to select the cursor mode, as follows:

#### BIT

| 66 | 55 | Cursor Display Mode   |
|----|----|-----------------------|
| 60 | 50 | Non-Blink             |
| 60 | 51 | Non-Display           |
| 61 | 50 | Blink 1/16 Field Rate |
| 61 | 51 | Blink 1/32 Field Rate |

Note that the ability to program both the start and end scan line for the cursor enables either block cursor or underline to be accomodated. Registers R14 and R15 are used to control the character position of the cursor over the entire 16K address field.

#### DISPLAY START ADDRESS AND LOW REGISTERS (R12,R13)

These registers together comprise a 14-bit register whose contents are the memory address of the first character of the displayed scan (the character on the top left of the video display). Subsequent memory addresses are generated by the VL68465E as a result of CCLK input pulses. Scrolling of the display is accomplished by changing R12 and R13 to the memory address associated with the first character of the desired line of text to be displayed first. Entire pages of text may be scrolled or changed as well as via R12 and R13.

#### CURSOR POSITION HIGH AND LOW REGISTERS (R14.R15)

These registers together comprise a 14-bit register whose contents are the memory address of the current cursor position. When the video display scan counter (MA lines) matches the contents of this register, and when the scan line counter (RA lines) falls within the bounds set by R10 and R11, the Cursor output becomes active. Bit 5 of the Mode Control Register (R8) may be used to delay the Cursor output by a full CCLK time to accomodate slowaccess memories.

#### LPSTB HIGH AND LOW REGISTERS (R16,R17)

These registers together comprise a 14-bit register whose contents are the light pen strobe position, in terms of the video display address at which the strobe occured. When the LPSTB input changes from LOW to HIGH, then, on the next negative-going edge of CCLK, the contents of the internal scan counter are stored in registers R16 and R17.

#### UPDATE ADDRESS HIGH AND LOW REGISTERS (R18,R19)

These registers together comprise a 14-bit register whose contents is the memory address at which the next read or update will occur (for transparent addressing mode, only). Whenever a read/update occurs, the update location automatically updates, to allow for fast updates or readouts of consecutive character locations. This is described elsewhere in this document.

#### **DUMMY LOCATION (R31)**

This register does not store any data, but is required to detect when transparent addressing updates occur. This is necessary to increment the Update Address Register and to set the Update Ready bit in the Status Register.

## VL6845E DESCRIPTION OF OPERATION

#### **REGISTER FORMATS**

Register pairs R12/R13, R14/R15, R16/ R17, and R18/R19 are formatted in one of two ways:

- 1) Straight Binary if register R8, bit2 is a zero.
- Row/Column if register R8, bit 2 is a one. In this case, the low byte is the Character Column, and the high byte is the Character Row.

Figure 2 illustrates the address sequence for the video display control for each mode. Note from Figure 2 that the straight binary mode has the advantage that all display memory addresses



#### VL6845E DESCRIPTION OF OPERATION (Cont.)

are stored in a continuous memory block, starting with address 0 and ending at 1919. The disadvantage with this method is that, if it is desired to change a displayed character location, the row and column identity of the location must be converted to its binary address before the memory may be written. The row/column mode, on the other hand. does not require this conversion. However, memory is not used as efficiently. since the memory addresses are not continuous (gaps exist). This requires that the system be equipped with more memory than is actually used, and this extra memory is wasted. Alternatively. address compression logic may be employed to translate the row/column format into a continuous address block.

In this way, the system designer may select whichever mode is best for the given application. The trade-offs between the modes involve the comparative costs of hardware and software. Straight-binary mode minimizes hardware requirements, and row/column addressing requires minimum software.

#### VIDEO DISPLAY RAM ADDRESS. LINES (MA0-MA13)

These signals are active-HIGH outputs that are used to address the video display RAM for character storage and display operations. The starting scan address is fully programmable and the ending scan address is determined by the total number of characters displayed, which is also programmable, in terms of characters per line and lines per frame.

There are two selectable address modes for MA0-MA13:

1. Binary

Characters are stored in successive memory locations. Thus, the software must be developed so that row and column coordinates are translated in sequentially numbered addresses for video display memory operations.

2. Row/Column

In this mode, MA0-MA7 function as column addresses CC0-CC7, and MA8-MA13 as row addresses CR0-CR5. In this case, the software may handle addresses in terms of row and column locations, but additional address compression circuits are needed to convert CC0-CC7 and CR0-CR5 into a memory efficient binary scheme.

# RASTER ADDRESS LINES (RA0-RA4)

These signals are active-HIGH outputs that are used to select each raster scan within an individual character row. The number of raster scan lines is programmable and determines the character height, including spaces between character rows.

The HIGH-order line, RA4, is unique in that it can also function as a strobe output pin when the VL6845E is programmed to operate in the "transparent address mode". In this case, the strobe is an active-HIGH output that is true at the time the video display RAM update address is gated onto the address lines, MA0-MA13. In this way, updates and readouts of the video display RAM can be made under control of the CRTC with only a small amount of external circuitry.

#### FIGURE 2. DISPLAY ADDRESS SEQUENCES (WITH START ADDRESS = 0) FOR 80 x 24 EXAMPLE



## STRAIGHT BINARY ADDRESSING SEQUENCE



## ROW/COLUMN ADDRESSING SEQUENCE



#### VL6845E DESCRIPTION OF OPERATION (Cont.)

#### MEMORY CONTENTION SCHEMES FOR SHARED MEMORY ADDRESSING

In a typical system, it is clear that both the VL6845E CRTC and the system MPU must be capable of addressing the video display memory. The VL6845E CRTC repetitively fetches character information to generate the video signals in order to keep the screen display active. The MPU occasionally accesses the memory to change the displayed information or to read out current data characters. Three ways of resolving this dual-contention requirement are apparent:

#### 1. MPU PRIORITY

In this technique, the address lines to the video display memory are normally driven by the VL6845E unless the MPU needs access, in which case the MPU addresses immediately override those from the VL6845E and the MPU has immediate access.

#### 2. PHASE 1/PHASE 2 (01/02) MEMORY INTERLEAVING

This method permits both the VL6845 and the MPU access the video display memory by time-sharing via system 01 and 02 clocks. During the 01 portion of each cycle (the time when E is LOW), the CRTC address outputs are gated to the video display memory. In the 02 time, the MPU address lines are switched in. In this

#### way, both the CRTC and the MPU have unimpeded access to the memory. (Figure 3a illustrates the timings)

#### 3. VERTICAL BLANKING

With this approach, the address Circuitry is identical to the case for MPU priority updates. The only difference is that the vertical retrace status bit (bit 5 of the status register) is used by the MPU so that access to the video display memory is only made during vertical blanking time (when bit 5 is a one). In this way, no visible screen perturbations result.

#### TRANSPARENT MEMORY ADDRESSING

In this mode of operation, the video display memory address lines are not switched by contention circuits, but are generated by the CRTC. In effect, the contention is handled by the CRTC. As a result, the schemes for accomplishing MPU memory acces are different:

#### 1. PHASE 1/PHASE 2 (01/02) INTERLEAVING

This mode is similar to the interleave mode used with shared memory. In this case, however, the 02 address is generated from the update address register (Registers R18 and R19) in the CRTC. Thus, the MPU must first load the address to be accessed into R18/R19 and then this address is always gated onto the MA lines during 02. (Figure 3b illustrates the timing)

2. HORIZONTAL/VERTICAL BLANKING In this mode, the update address register is loaded by the MPU, but is only gated onto the MA lines during horizontal or vertical blank times, so memory accesses do not interfere with the display appearance. To signal when the update address is on the MA lines, an update strobe (STB) is provided as an alternative function of pin 34. Data hold latches are necessary to temporarily retain the character to be stored until the retrace time occurs. In this way, the system MPU is not halted while waiting for the blanking time to arrive.

#### FIGURE 3a. PHASE 1/PHASE 2 SHARED INTERLEAVING



#### FIGURE 3b. PHASE 1/PHASE 2 TRANSPARENT INTERLEAVING



### ABSOLUTE MAXIMUM RATINGS

| Supply Voltage       | -0.3 V to +7.0 V         |
|----------------------|--------------------------|
| Input/Output Voltage | e,<br>- 0.3 V to + 7.0 V |
| Operating Tempera    | ture,                    |
| Top                  | 0°C to 70°C              |
| Storage Temperatur   | re,                      |
| TSTG                 | - 55°C to 150°C          |

Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only. Functional operation of this device at these or any other conditions above those indicated in the operational sections of this specification is not implied and exposure to absolute maximum rating conditions for extended periods may affect device reliability.

# DC CHARACTERISTICS TA = 0° to 70°C, VCC = 5.0 V $\pm$ 5%, unless otherwise noted

| Symbol | Characteristic                                                                             | Min  | Тур | Max          | Unit     |
|--------|--------------------------------------------------------------------------------------------|------|-----|--------------|----------|
| VIH    | Input HIGH Voltage                                                                         | 2.0  |     | Vcc          | V        |
| VIL    | Input LOW Voltage                                                                          | -0.3 |     | 0.8          | V        |
| IIN    | Input Leakage (o2, R/W, RES, CS, RS, LPSTB, CCLK)                                          | -    |     | 2.5          | μA       |
| ITSI   | Three-State Input Leakage (DBO-DB7) VIN = 0.4 to 2.4 V                                     | -    |     | ±10.0        | μA       |
| VOH    | Output HIGH Voltage<br>ILOAD = $-205 \mu A$ (DBO-DB7)<br>ILOAD = $-100 \mu A$ (all others) | 2.4  |     | _            | V        |
| VOL    | Output LOW Voltage<br>ILOAD = 1.6 mA                                                       | -    |     | 0.4          | V        |
| PD     | Power Dissipation                                                                          | -    | 325 | 650          | mW       |
| CI     | Input Capacitance<br>o2,R/W,RES,CS,RS,LPSTB,CLK,<br>DBO-DB7                                |      |     | 10.0<br>12.5 | pF<br>pF |
| со     | Output Capacitance                                                                         | _    |     | 10.0         | pF       |

# VL6845 CHARACTERISTICS

To ensure system compatibility, all CRTC timing is referenced by bus and character clock speed specification rather than device type. Thus, for a given MPU and character clock speed, the entire VL6845 family will adhere to the same timing regardless of version number. Table 13 presents a cross reference between specifications and device numbers.

The bus timing test load is shown in Figure 4. Signal timing for the CRTC is described in Table 14, and Table 15 describes CRTC video timing. Light pen timing is described in Table 16.

#### TABLE 13: VL6845 SPECIFICATION/ PART NUMBER REFERENCE

| VL6845E-24  | VTI-24 |
|-------------|--------|
| VL6845E-34  | VTI-34 |
| VL6845R-23  | VTI-23 |
| VL6845R-24  | VTI-24 |
| VL6845R-33  | VTI-33 |
| VL6845R-34  | VTI-34 |
| VL6845R-35  | VTI-35 |
| VL68C45R-23 | VTI-23 |
| VL68C45R-24 | VTI-24 |
| VL68C45R-33 | VTI-33 |
| VL68C45R-34 | VTI-34 |
| VL68C45R-35 | VTI-35 |
| VL68C45S-23 | VTI-23 |
| VL68C45S-24 | VTI-24 |
| VL68C45S-33 | VTI-33 |
| VL68C45S-34 | VTI-34 |
| VL68C45S-35 | VTI-35 |
|             |        |

# FIGURE 4. TEST LOAD



 $\begin{array}{l} R=11\ \text{K}\ \Omega\ \text{FOR}\ \text{DB0}{--}\text{DB7}\\ R=24\ \text{K}\ \Omega\ \text{FOR}\ \text{ALL}\ \text{OTHER}\ \text{OUTPUTS}\\ C=130\ \text{pF}\ \text{TOTAL}\ \text{FOR}\ \text{DO}{--}\text{D7}\\ C=30\ \text{pF}\ \text{ALL}\ \text{OTHER}\ \text{OUTPUTS}\\ \end{array}$ 

NOTES: 1. VOLTAGE LEVELS SHOWN ARE 0.4 V AND 2.4 V 2. MEASUREMENT POINTS SHOWN ARE 0.8 V AND 2.0 V

# VL6845 CHARACTERISTICS (Cont.) TABLE 14: CRTC BUS TIMING CHARACTERISTICS

|        |                              | VT  | 1-23 | νт  | -24 | VТ  | -33 | VT<br>VT | -34<br> -35 |      |
|--------|------------------------------|-----|------|-----|-----|-----|-----|----------|-------------|------|
| Symbol | Parameter                    | Min | Max  | Min | Max | Min | Max | Min      | Max         | Unit |
| tcyc   | Cycle Time                   | 500 |      | 500 |     | 333 |     | 333      |             | ns   |
| pWEL   | Pulse Width, E LOW           | 190 |      | 190 |     | 140 |     | 140      |             | ns   |
| pWEH   | Pulse Width, E HIGH          | 200 |      | 200 |     | 150 |     | 150      |             | ns   |
| tR     | Clock Rise Time              |     | 30   |     | 30  |     | -30 |          | 30          | ns   |
| tF     | Clock Fall Time              |     | 30   |     | 30  |     | 30  |          | 30          | ns   |
| tAH    | Address Hold Time (RS)       | 0   |      | 0   |     | 0   |     | . 0      |             | ns   |
| tAS    | RS Setup Time                | 40  |      | 40  |     | 30  |     | - 30     |             | ns   |
| tCS    | R/W, CS Setup                | 40  |      | 40  |     | 30  |     | 30       |             | ns   |
| tCH    | R/W, CS Hold Time            | 0   |      | 0   |     | 0   |     | 0        |             | ns   |
| tDHR   | Read Data Hold Time          | 20  | 60   | 20  | 60  | 20  | 60  | 20       | 60          | ns   |
| tDHW   | Write Data Hold Time         | 10  |      | 10  |     | 10  |     | 10       |             | ns   |
| tDDR   | Peripheral Output Delay Time | 0   | 150  | 0   | 150 | 0   | 130 | 0        | 130         | ns   |
| tDSW   | Peripheral Setup Time        | 60  |      | 60  |     | 60  |     | 60       |             | ns   |

# **TIMING DIAGRAM**

VL6845 BUS TIMING



NOTES: 1. VOLTAGE LEVELS SHOWN ARE V1≤0.4V, Vh≥2.4V 2. MEASUREMENT POINTS SHOWN ARE 0.8V AND 2.0V.

# VL6845 CHARACTERISTICS (Cont.) TABLE 15: CRTC VIDEO TIMING CHARACTERISTICS

|        |                            | VTI-23 |     | VTI-24 |     | VTI-33 |     | VTI-34 |     | VTI-35 |     |      |
|--------|----------------------------|--------|-----|--------|-----|--------|-----|--------|-----|--------|-----|------|
| Symbol | Parameter                  | Min    | Max | Unit |
| pWCL   | Clock Pulse Width, LOW     | 150    |     | 110    |     | 150    |     | 110    |     | 100    |     | ns   |
| pWCH   | Clock Pulse Width, HIGH    | 150    |     | 120    |     | 150    |     | 120    |     | 100    |     | ns   |
| fC     | Clock Frequency            |        | 3.0 |        | 4.0 |        | 3.0 |        | 4.0 |        | 5.0 | MHz  |
| tR     | Clock Rise Time            | 1      | 20  |        | 20  |        | 20  |        | 20  |        | 20  | ns   |
| tF     | Clock Fall Time            |        | 20  |        | 20  |        | 20  |        | 20  |        | 20  | ns   |
| tMAD   | Memory Address Delay Time  |        | 160 |        | 140 |        | 160 |        | 140 |        | 140 | ns   |
| tRAD   | Raster Address Delay Time  |        | 160 |        | 150 |        | 160 |        | 150 |        | 140 | ns   |
| tDTD   | Display Timing Delay Time  |        | 250 |        | 250 |        | 250 |        | 250 |        | 200 | ns   |
| tHSD   | Horizontal Sync Delay Time |        | 250 |        | 200 |        | 250 |        | 200 |        | 200 | ns   |
| tVSD   | Vertical Sync Delay Time   |        | 250 |        | 250 |        | 250 |        | 250 |        | 200 | ns   |
| tCDD   | Cursor Display Delay Time  |        | 250 |        | 250 |        | 250 |        | 250 |        | 200 | ns   |

# TIMING DIAGRAM

VL6845 VIDEO TIMING



NOTES: TIMING MEASUREMENTS ARE REFERENCED TO AND FROM A LOW VOLTAGE OF 0.8 VOLTS AND A HIGH VOLTAGE OF 2.0 VOLTS UNLESS OTHERWISE SPECIFIED

# VL6845 AC CHARACTERISTICS

# TABLE 16: CRTC LIGHT PEN TIMING CHARACTERISTICS

|        |                              | VT  | -23 | VT  | 1-24 | VT  | -33 | VT<br>VT |     |      |
|--------|------------------------------|-----|-----|-----|------|-----|-----|----------|-----|------|
| Symbol | Parameter                    | Min | Max | Min | Max  | Min | Max | Min      | Max | Unit |
| pwLPH  | Light Pen Strobe Pulse Width | 80  |     | 60  |      | 80  |     | 60       |     | ns   |
| tLPD1  | Light Pen Display Time 1     |     | 120 |     | 70   |     | 120 |          | 70  | ns   |
| tLPD2  | Light Pen Display Time 2     |     | 0   |     | 0    |     | 0   |          | 0   | ns   |

# **TIMING DIAGRAM**

#### VL6845 LIGHT PEN TIMING



# **CROSS REFERENCE GUIDE**

| VTI Device  | Replaces  | Bus Frequency<br>(MHz) | Character Clock<br>(MHz) |
|-------------|-----------|------------------------|--------------------------|
| VI 6845B-23 | MC68B45B  | 20                     | 3.0                      |
| VI 6845B-23 | MC68A45   | 1.5                    | 3.0                      |
| VI 6845B-23 | MC6845B   | 1.0                    | 3.0                      |
| VL68C45B-23 | MC68B45B1 | 2.0                    | 3.0                      |
| VL68C45R-23 | MC68A45R1 | 1.5                    | 3.0                      |
| VL68C45R-23 | MC6845R1  | 1.0                    | 3.0                      |
| VL68C45R-23 | HD68B45R  | 2.0                    | 3.0                      |
| VL68C45R-23 | HD68A45R  | 1.5                    | 3.0                      |
| VL68C45R-23 | HD6845R   | 1.5                    | 3.0                      |
| VL68C45S-24 | HD68B45S  | 2.0                    | 3.7                      |
| VL68C45S-24 | HD68A45S  | 1.5                    | 3.7                      |
| VL68C45S-24 | HD6845S   | 1.0                    | 3.7                      |
| VL6845E-24  | SY6845EA  | 2.0                    | 3.7                      |
| VL6845E-24  | SY6845E   | 1.0                    | 3.7                      |
| VL6845R-23  | SY6845RA  | 2.0                    | 2.5                      |
| VL6845R-23  | SY6845R   | 1.0                    | 2.5                      |

# **VL6845 REGISTER COMPARISON**

Non-interlace

|                                      | VL68C45R                         | VL6845R<br>MC6845                                                                                                                       | VL68C45S                                                                                            |                                                                 |                                                |
|--------------------------------------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|-----------------------------------------------------------------|------------------------------------------------|
| Register                             | MC6845R1                         | HD6845R                                                                                                                                 | HD6845S                                                                                             | SY6545-1                                                        | VL6845E                                        |
| R0 Horizontal Tot                    | Tot-1                            | Tot-1                                                                                                                                   | Tot-1                                                                                               | Tot-1                                                           | Tot-1                                          |
| R1 Horizontal Disp                   | Actual                           | Actual                                                                                                                                  | Actual                                                                                              | Actual                                                          | Actual                                         |
| R2 Horizontal Sync                   | Actual                           | Actual                                                                                                                                  | Actual                                                                                              | Actual                                                          | Actual                                         |
| R3 Horizontal and Vert<br>Sync Width | Horizontal                       | Horizontal                                                                                                                              | Horizontal and<br>Vertical                                                                          | Horizontal and<br>Vertical                                      | Horizontal and<br>Vertical                     |
| R4 Vertical Tot                      | Tot-1 (0-127)                    | Tot-1                                                                                                                                   | Tot-1                                                                                               | Tot-1                                                           | Tot-1                                          |
| R5 Vertical Tot Adj                  | Any Value                        | Any Value                                                                                                                               | Any Value                                                                                           | Any Value Except R5<br>= (R9H) • X                              | Any Value                                      |
| R6 Vertical Disp                     | Any Value <r4<br>(0-255)</r4<br> | Any Value <r4< td=""><td>Any Value <r4< td=""><td>Any Value <r4< td=""><td>Any Value <r4< td=""></r4<></td></r4<></td></r4<></td></r4<> | Any Value <r4< td=""><td>Any Value <r4< td=""><td>Any Value <r4< td=""></r4<></td></r4<></td></r4<> | Any Value <r4< td=""><td>Any Value <r4< td=""></r4<></td></r4<> | Any Value <r4< td=""></r4<>                    |
| R7 Vertical Sync Pos                 | Actual-1 (0-255)                 | Actual-1                                                                                                                                | Actual-1                                                                                            | Actual-1                                                        | Actual-1                                       |
| R8 Mode Reg<br>Bits 0 and 1          | Interlace Mode Select            | Interlace Mode Select                                                                                                                   | Interlace Mode Select                                                                               | Interlace Mode Select                                           | Interlace Mode Select                          |
| Bits 2                               | -                                | _                                                                                                                                       |                                                                                                     | Row/Column or<br>Straight Binary<br>Addressing                  | Row/Column or<br>Straight Binary<br>Addressing |
| Bits 3                               | -                                | _                                                                                                                                       |                                                                                                     | Shared or<br>Transparent Addr                                   | Shared or<br>Transparent Addr                  |
| Bits 4                               |                                  | —                                                                                                                                       | Dispen Skew                                                                                         | Dispen Skew                                                     | Dispen Skew                                    |
| Bits 5                               |                                  | _                                                                                                                                       | Dispen Skew                                                                                         | Cursor Skew                                                     | Cursor Skew                                    |
| Bits 6                               |                                  | _                                                                                                                                       | Cursor Skew                                                                                         | RA4/UPSTB                                                       | RA4/UPSTB                                      |
| Bits 7                               | -                                |                                                                                                                                         | Cursor Skew                                                                                         | Transparent Mode<br>Select                                      | Transparent Mode<br>Select                     |
| R9 Scan Lines                        | Tot-1                            | Tot-1                                                                                                                                   | Tot-1                                                                                               | Tot-1                                                           | Tot-1                                          |
| R10 Cursor Start                     | Actual                           | Actual                                                                                                                                  | Actual                                                                                              | Actual                                                          | Actual                                         |
| R11 Cursor End                       | Actual                           | Actual                                                                                                                                  | Actual                                                                                              | Actual                                                          | Actual                                         |
| R12/R13 Disp Addr                    | Write Only                       | Write Only                                                                                                                              | Read/Write                                                                                          | Write Only                                                      | Write Only                                     |
| R14/R15 Cursor POS                   | Write Only                       | Write Only                                                                                                                              | Read/Write                                                                                          | Read/Write                                                      | Read/Write                                     |
| R16/R17 Lpen Reg                     | Read Only                        | Read Only                                                                                                                               | Read Only                                                                                           | Read Only                                                       | Read Only                                      |
| R18/R19 Update<br>Addr Reg           | N/A                              | N/A                                                                                                                                     | N/A                                                                                                 | Transparent Mode<br>Only                                        | Transparent Mode<br>Only                       |
| R31 Dummy Reg                        | N/A                              | N/A                                                                                                                                     | N/A                                                                                                 | Transparent Mode<br>Only                                        | Transparent Mode<br>Only                       |
| Status Reg                           | No                               | No                                                                                                                                      | No                                                                                                  | Yes                                                             | Yes                                            |
| Interlace Sync                       |                                  | • • • • • • • • • • • • • • • • • • •                                                                                                   | • • • • • • • • • • • • • • • • • • •                                                               |                                                                 |                                                |
| R0                                   | Tot-1 = Odd                      | Tot-1 = Odd                                                                                                                             | Tot-1 = Odd                                                                                         | Tot-1 = Odd                                                     | Tot-1 = Odd or Even                            |
| Interlace Sync and Vide              | eo                               |                                                                                                                                         |                                                                                                     |                                                                 |                                                |
| R4 Vertical                          | Tot-1                            | Tot-1                                                                                                                                   | Tot-1                                                                                               | Tot/2-1                                                         | Tot-1                                          |
| R6 Vert Disp                         | Tot/2                            | Tot/2                                                                                                                                   | Tot                                                                                                 | Tot/2                                                           | Tot                                            |
| R7 Vert Sync                         | Actual-1                         | Actual-1                                                                                                                                | Actual-1                                                                                            | Actual/2                                                        | Actual-1                                       |
| R9 Scan Lines                        | Tot-2 Odd/Even                   | Tot-1 Only Even                                                                                                                         | Tot-2 Odd/Even                                                                                      | Tot-1 Odd/Even                                                  | Tot-1 Odd/Even                                 |
| R10 Cursor Start<br>R11 Cursor End   | Both Odd or<br>Both Even         | Both Odd or<br>Both Even                                                                                                                | Odd/Even<br>Odd/Even                                                                                | Odd/Even<br>Odd/Even                                            | Odd/Even<br>Odd/Even                           |

# VMC68C45 MEGACELL DESIGN KIT CRT CONTROLLER MEGACELL

#### **FEATURES**

- Completely integrated with VTI's extensive IC design tools and libraries
- 2-micron CMOS 68C45 Megacell configurable as:

| 68C45R  | <ul> <li>— CMOS equivalent to</li> </ul> |
|---------|------------------------------------------|
|         | Motorola 6845R                           |
|         | CRTC                                     |
| 68C45R1 | CMOS equivalent to                       |
|         | Motorola 6845R1                          |
|         | Enhanced CRTC                            |

- 68C45S CMOS equivalent to Hitachi 6845S CRTC
- 68C45SY CMOS CRTC similar to Synertek 6545 CRTC
- 4.5 MHz video memory interface
- 3 MHz system processor interface
- Compatible with the VTI bus architecture
- Programmable Display Enable and Cursor delays (standard for S and SY versions—optional for R version)
- Row/column display memory addressing (SY version)
- Double-width character control

# **OPTIONAL FEATURES**

- 16K, 32K, or 64K display Memory Address range (14-, 15-, or 16-bits)
- Programmable Vertical Sync pulse width
- 7-, 8-, or 9-bit Vertical Row counter

## DESCRIPTION

Megacells are building block equivalents of standard LSI functions that can be combined with other megacells, standard cells or compiled cells to create custom User Specific ICs (USICs). Megacells are fully compatible with VTI's other cell technologies and design tools.

The VTI bus architecture allows multiple megacells to be combined on a single IC, along with additional cells from VTI's extensive libraries. This decreases the design time, cost and size of complex systems. A detailed simulation model provided with each megacell further reduces design verification time.

#### VMC68C45 MEGACELL DESIGN KIT DESCRIPTION

The VMC68C45 Megacell Design Kit includes the simulation models and icons required to permit designers using VTI's IC design tools to develop custom CRT controller designs.

Using the proven 68C45 LSI functional building block, implementing a specific CRT controller application requires only the combination of a 68C45 megacell with other logic on one or more VLSI ICs. For example, if a 68C45 megacell is combined with a ROM megacell character generator and "glue" logic, a complete CRT adapter for monochrome or color applications can be designed.

# CONNECTOR DIAGRAM



# SIGNAL DESCRIPTIONS

The following signals function the same on the VMC68C45 megacells and on the VL6845 family of CRT Controller ICs.

| Signal  | I/O          | Description      |
|---------|--------------|------------------|
| RS      | Input        | Register Select  |
| E       | Input        | Enable           |
| CCLK    | Input        | Character Clock  |
| LPSTB   | Input        | Light Pen Strobe |
| D0-D7   | Input/Output | Data Bus         |
| RA0-RA4 | Output       | Raster Address   |
| HS      | Output       | Horizontal Sync  |
| RESETB  | Output       | Reset            |

The following signals are unique or enhanced on the VMC68C45 megacells.

| Signal                        | I/O              | Description                                                                                                                                                                                                                                                                                                                                                        |
|-------------------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RNW                           | Input            | Same as $R/\overline{W}$ , input on VL6845.                                                                                                                                                                                                                                                                                                                        |
| CS                            | Input            | Same input as on VL6845, except active HIGH.                                                                                                                                                                                                                                                                                                                       |
| DW                            | Input            | Double-width input—this input places the 68C45 in a double-width display mode.                                                                                                                                                                                                                                                                                     |
| AENB                          | Input            | Address Enable input—when asserted LOW (AENB = "0") the MA outputs are enabled.<br>AENB = "1" forces the MA outputs into a HIGH impedance state.                                                                                                                                                                                                                   |
| C6845R,<br>C6845S,<br>C6545SY | Input            | One of these three inputs is tied HIGH to select the version of the 68C45 used in your application.<br>The remaining two inputs must be grounded. NOTE: the 68C45SY megacell does not provide<br>6545 transparent addressing or the 6545 status register.                                                                                                          |
| MA0-MA13,<br>14, 15           | Output           | 14-, 15-, or 16-bit Video Memory Address bus—These tri-state outputs provide the binary address to the external video RAM. If row/column addressing is selected (SY version only) this bus will provide row/column addressing to the external RAM instead of binary addressing. The AENB input signal can be used to place the MA bus in the HIGH impedance state. |
| DE                            | Output           | Display Enable output—active (DE = "1") when the 68C45 is generating active display information. The S version can be programmed with a 0, 1, or 2 character delay. The SY version can be programmed for a 0 or 1 character delay.                                                                                                                                 |
| CURSOR                        | Output           | Cursor output—this signal is HIGH when the raster scan coincides with the programmed cursor position. The S version can be programmed with a 0, 1, or 2 character delay. The SY version can be programmed for a 0 or 1 character delay.                                                                                                                            |
| VS                            | Output           | Vertical Sync output—active HIGH pulse which determines the vertical placement of the video data. An optional feature permits programming the Vertical Sync pulse width.                                                                                                                                                                                           |
| LD0-LD13,<br>14, 15           | Input/<br>Output | 14-, 15-, or 16-bit Advanced Memory Address bus—separate video memory address information on this bus precedes the information on the MA bus by one character clock. This bus is provided to interface with a separate strip of logic for split display capability.                                                                                                |
| VDRA (reserved)               | n/c              | Reserved for future expansion—to be left unconnected.                                                                                                                                                                                                                                                                                                              |

# **ORDER INFORMATION**

VMC68C45-c\*-m\*\* Complete Design Kit for CMOS 68C45 Megacell

| *с | Computer Type      | **m | Media Format    |  |
|----|--------------------|-----|-----------------|--|
| Α  | Apollo workstation | 1   | Floppy diskette |  |
| V  | VAX workstation    | 2   | Magnetic tape   |  |
| R  | RIDGE workstation  | 3   | Cartridge       |  |
| Е  | ELXSI workstation  | -   |                 |  |
| W  | WANG workstation   |     |                 |  |

# VL82C37A



# **CMOS DIRECT MEMORY ACCESS (DMA) CONTROLLER**

# FEATURES

- Low-power CMOS version of popular 8237A DMA controller
- Four DMA channels
- Individual enable/disable control of DMA requests
- Directly expandable to any number of channels
- Independent auto-initialize feature for all channels
- Address increment or decrement
- High-performance: up to 8 MHz (VL82C37A-08)
- Transfers may be terminated by end of process input
- Software controlled DMA requests

# **PIN DIAGRAM**

| VL82C37A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                           |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|
| IOR<br>IOW<br>MEMR<br>VCC<br>HLDA<br>HLDA<br>ASTB<br>CLK<br>HLDA<br>CS<br>CLK<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2<br>DACK2 | 1<br>2<br>3<br>4<br>5<br>6<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 | 40 A7<br>39 A6<br>38 A5<br>37 A4<br>36 EOF<br>35 A3<br>34 A2<br>33 A4<br>32 A0<br>31 VCC<br>30 DB0<br>29 DB1<br>28 DB3<br>26 DA0<br>24 DA0<br>24 DA0<br>23 DB5<br>24 DB5<br>22 DB5<br>23 DB5<br>23 DB5<br>24 DB5<br>25 DB5 | -<br>;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |

 Independent polarity control for DREQ and DACK signals

# DESCRIPTION

The VL82C37A Direct Memory Access (DMA) Controller serves as a peripheral interface circuit for microprocessor system, and is designed to improve system performance by allowing external devices to directly transfer information from the system memory. Memory-to-memory transfer capability is also provided. The VL82C37A DMA Controller offers many programmable control features that enhance data throughput and system performance. Dynamic reconfiguration is permitted under program control. The VL82C37A is designed to be used with an external 8-bit address register such as the 8282. In addition to the four independent channels, the VL82C37A is expandable to any number of channels by cascading additional controller devices.

Three basic transfer modes allow the user to program the types of DMA service. Each channel can be individually programmed to autoinitialize to its original condition following an End-of-Process (EOP) input.Each channel also has a 64K address and word count handling ability.

The VL82C37 DMA Controller is available in 4 MHz, 5 MHz, and 8 MHz clock frequencies.



# **ORDER INFORMATION**

| Part<br>Number | Clock<br>Frequency | Package                     |
|----------------|--------------------|-----------------------------|
| VL82C37A-04-PC |                    | Plastic DIP                 |
| VL82C37A-04-CC | 4 MHz              | Ceramic DIP                 |
| VL82C37A-04-QC |                    | Plastic Leaded Chip Carrier |
| VL82C37A-05-PC |                    | Plastic DIP                 |
| VL82C37A-05-CC | 5 MHz              | Ceramic DIP                 |
| VL82C37A-05-QC |                    | Plastic Leaded Chip Carrier |
| VL82C37A-08-PC |                    | Plastic DIP                 |
| VL82C37A-08-CC | 8 MHz              | Ceramic DIP                 |
| VL82C37A-08-QC |                    | Plastic Leaded Chip Carrier |

Note: Operating temperature is 0°C to +70°C

# VL82C37A

# SIGNAL DESCRIPTIONS

| Signal<br>Name | Pin<br>Number       | Signal<br>Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CLK            | 12                  | Clock input: Controls the internal operations of the VL82C37A DMA Controller and its rate of data transfers. This input may be driven at up to 4 MHz for the standard VL82C37A-04 and up to 8 MHz for the VL82C37A-08.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| CS             | . <b>11</b>         | Chip Select: An active-low input used to select the VL82C37A as an I/O device during the<br>idle cycle, allows CPU communication on the data bus.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| RESET          | 13                  | Reset: An active-high input that clears the Command, Request, and Temporary Registers,<br>clears the first/last flip-flop, and sets the Mask Register.The device is in the idle cycle<br>following a Reset signal.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| READY          | 6                   | Ready: An input that extends the memory read and write pulses from the VL82C37A<br>accomodating slow memories or I/O peripheral devices. During its specified setup/hold<br>time, Ready must not make transitions.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| HLDA           | 7                   | Hold Acknowledge: This active-high signal from the CPU indicates that it has relinquished<br>control of the system busses.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| DREQ0-DREQ3    | 19 - 16             | DMA Request: These lines are individual asynchronous channel request inputs.<br>Peripheral circuits use these lines to obtain DMA service. In fixed Priority, DREQ0 has<br>the highest priority and DREQ3 has the lowest priority. Activating the DREQ line of a<br>channel generates a request. DACK then acknowledges the recognition of DREQ signal.<br>Polarity of DREQ is programmable. Reset initializes these lines to active high. DREQ<br>must be sustained until the corresponding DACK becomes active.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| DB0 - DB7      | 30 - 26,<br>23 - 21 | Data Bus: These lines are bidirectional, three-state signals that connect to the system data bus. The outputs are enabled in the program condition during the I/O read to output the contents of an Address Register, a Status Register, the Temporary Register, or a Word Count Register to the CPU. The outputs are disabled and the inputs are read during an I/O Write cycle when the CPU is programming the VL82C37A control registers. During DMA cycles the most significant eight bits of the address are sent onto the data bus and are strobed into an external latch by ADSTB. In memory-to-memory operations, data from the memory comes into the VL82C37A on the data bus during the read-from-memory transfer. In the write-to-memory transfer, the data bus outputs determine the placement of the data, not the new memory location.                                                                                                                                                                                                                                                              |
| ĪOR            | 1                   | I/O Read: This is a bidirectional, active-low, three-state line. In the idle cycle, it is an input<br>control signal used by the CPU to read the control registers. In the active cycle, it is an<br>output control signal used by the VL82C37A to access data from a peripheral during a<br>DMA Write transfer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| IOW            | 2                   | I/O Write: This signal is a bidirectional actie-low, three-state line. It is used by the CPU to<br>load information into the VL82C37A DMA Controller. In the active cycle, it is used as an<br>output control signal used by the VL82C37A to load data to the peripheral during a DMA<br>read transfer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| EOP            | 36                  | End of Process: This is an active-low bidirectional signal, which provides data on the completion of DMA services and is available at the bidirection EOP pin. The VL82C37A allows an external signal to terminate an active DMA service, by pulling the EOP input low with an external EOP signal. The VL82C37A also generates a pulse when the terminal count (TC) for any channel is achieved. This generates an EOP signal that is active on the EOP Line. When EOP is received, either internally or externally, it will cause the VL82C37A to terminate the service, reset the request, and, if auto-initialize is enabled, to write the base registers to the current registers of that channel. The mask bit and TC bit in the status word will be set for the currently active channel by EOP, unless the channel is programmed for auto-initialize. In that case, the mask bit remains unchanged. During memory-to-memory transfers, EOP will be output when the TC for channel 1 occurs. To prevent erroneous end-of-process inputs, EOP should be tied high with a pull-up resistor if it is not used |
| vcc            | 5, 31               | +5 V ±5% power supply                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| GND            | 20                  | Ground                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |



# SIGNAL DESCRIPTIONS (CONT.)

| Signal<br>Name | Pin<br>Number     | Signal<br>Description                                                                                                                                                                                                                                                                                                       |
|----------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A0 - A3        | 32 - 35           | The four least significant address lines: These lines are bidirectional three-state signals.<br>In the idle cycle, they are inputs used by the CPU to address the register to be loaded or<br>read. In the active cycle they are outputs that provide the lower four bits of the output<br>address to the system.           |
| A4 - A7        | 37 - 40           | The four most significant address lines: These lines are three-state outputs that provide<br>four bits of address. They are enabled only during the DMA service.                                                                                                                                                            |
| HRQ            | 10                | Hold Request: This is the hold request to the CPU. It is used to request control of the<br>system bus. If the corresponding mask bit is clear, the presence of any valid DREQ<br>causes the VL82C37A to issue the HRQ signal. After HRQ is asserted, at least one clock<br>cycle (TCY) must occur before HLDA can be valid. |
| DACK0 - DACK3  | 25, 24, 14,<br>15 | DMA Acknowledge: This signal is used to notify an individual peripheral when it has been granted a DMA cycle. The sense of these lines is programmable; Reset initializes them to an active-low.                                                                                                                            |
| AEN            | 9                 | Address Enable: This active-high line enables the 8-bit latch containing the upper eight<br>address bits onto the system address bus. It can also be used to disable other system<br>bus drivers during DMA transfers.                                                                                                      |
| ADSTB          | 8                 | Address Strobe: This active-high is used to strobe the upper address byte into an external latch.                                                                                                                                                                                                                           |
| MEMR           | 3                 | Memory Read: This active-low signal is a three-state output used to access data from a<br>selected memory location during a DMA read or memory-to-memory transfer.                                                                                                                                                          |
| MEMW           | 4                 | Memory Write: This signal is an active-low three-state output used to write data to a<br>selected memory location during a DMA write or memory-to-memory transfer.                                                                                                                                                          |

# **TABLE 1. INTERNAL REGISTERS**

| Name                          | Size    | Number |
|-------------------------------|---------|--------|
| Base Address Registers        | 16 bits | 4      |
| Base Word Count Registers     | 16 bits | 4      |
| Current Address Registers     | 16 bits | 4      |
| Current Word Count Registers  | 16 bits | 4      |
| Temporary Address Register    | 16 bits | 1      |
| Temporary Word Count Register | 16 bits | 1      |
| Status Register               | 8 bits  | 1      |
| Command Register              | 8 bits  | 1      |
| Temporary Register            | 8 bits  | 1      |
| Mode Registers                | 6 bits  | 4      |
| Mask Register                 | 4 bits  | 1      |
| Request Register              | 4 bits  | 1      |


# FUNCTIONAL DESCRIPTION

The internal registers and major logic blocks of the VL82C37A are shown in the block diagram. Data interconnection paths are also shown, but the various control signals between the blocks are not. The VL82C37A contains 344 bits of internal register memory. Figure 3 describes these registers and shows them by size. A complete description of the registers and their functions can be found in the Register Descriptions section.

The VL82C37A contains three basic control logic blocks. The Timing Control block generates internal timing and external control signals for the VL82C37A. The program command control block decodes the various commands given to the VL82C37A by the microprocessor before servicing a DMA Request. Further, it decodes the mode control word used to select the type of DMA during the servicing. The priority encoder block settles priority contention between DMA channels requesting service at the same time.

The external clock drives the timing control block. In most VL82C37A systems, this clock will usually be the Ø2 TTL clock from an VL82C84A. For 8085AH-2 systems above 3.9 MHz, the 8085 CLK(OUT) will not meet VL82C37A-05 (5 MHz) clock low and high time requirements. In this case, an external clock should be used to drive the VL82C37A-05.

#### DMA OPERATION

The VL82C37A is designed to operate in two major cycles: the idle and active . Several states are contained in each device cycle. The VL82C37A supports seven separate states, each being one full clock period. State I (SI), the inactive state, is entered when the VL82C37A has no valid DMA requests pending. While in SI, the DMA controller is inactive but may be in the program condition, being programmed by the processor. State 0 (S0) is the first state of a DMA service. The VL82C37A has requested a hold, but the processor has not yet responded with an acknowledge. The VL82C37A may still be programmed until it receives HLDA from the CPU. An acknowledge from the CPU signals that DMA transfers may begin. S1, S2, S3 and S4 are the functional states of the DMA service. If more time is needed to

complete a transfer than is available with normal timing, wait states (WS) can be placed between S2 or S3 and S4 by using the Ready line on the VL82C37A. The data is transferred directly from the I/O device to memory (or vice versa) with IOR and MEMW (or MEMR and IOW) being active simultaneously. The data is not read into or driven out of the VL82C37A during I/O-to-memory or memory-to-I/O DMA transfers.

To complete memory-to-memory transfers requires a read-from and a write-to-memory. The states, which resemble the normal working states, use two-digit numbers for identification. Eight states are needed for each transfer: the first four states (S11, S12, S13, S14), are used for read-frommemory and the last four states (S21, S22, S23, S24), for the write-to-memory of the transfer.

#### IDLE CYCLE

When no channels are requesting service, the VL82C37A enters the idle cycle and performs SI states, sampling the DREQ lines every clock cycle to determine if any channel is requesting a DMA service. The device also samples CS, looking for an attempt by the microprocessor to write or read to the internal registers of the VL82C37A. When CS is low and HLDA is low, the VL82C37A initiates the program condition. The CPU now establishes, changes or inspects the internal definition of the part by reading from or writing to the internal register. Address lines AO-A3 are inputs to the device. They select registers that will be read or written. The IOR and IOW lines are used to select and time reads or writes. Because of the number and size of the internal registers, an internal flip-flop is used to generate one more bit of address. This bit is used to determine the upper or lower byte of the 16-bit address and Word Count Registers. This flip-flop can be reset by a separate software command.

Special software commands executed in the VL82C37A during the program condition are decoded as sets of addresses with the CS and IOW signals. The commands do not use the data bus. Clear First/Last Flip-Flop and Master Clear instructions are included.

#### ACTIVE CYCLE

When the VL82C37A is in the idle cycle and a nonmasked channel requests a

DMA service, the device outputs an HRQ to the microprocessor and then enters the active cycle. During this cycle the DMA service takes place, in one of four modes.

In the single transfer mode, the device is programmed to make only one transfer. The word count is decremented and the address decremented or incremented, following each transfer. When the word countis completed from zero to FFFFH, a Terminal Count (TC) causes an autoinitialize if the channel has been so programmed.

The DREQ signal must be held active until DACK becomes active, in order to be recognized. If DREQ is held active for the entire single transfer, HRQ will become inactive and release the bus to the system. It again goes active and, upon receipt of a new HLDA, another single transfer is performed. In 8080A, 8085AH, 8088, or 8086 systems this insures one full machine cycle execution between DMA transfers. Details of timing between the VL82C37A and other bus control protocols depends upon the characteristics of the microprocessor involved.

In the block transfer mode, the device is activated by the DREQ signal to continue making transfers during the service until a TC, caused by word count going to FFFFH, or an external end of process (EOP) is encountered. DREQ need only be held active until DACK becomes active. An auto-initialization will occur at the end of the service, if the channel has been programmed for it.

In the demand transfer mode the device is programmed to continue making transfers until a TC or external EOP is encountered or until the DREQ signal goes inactive. Transfers may continue until the I/O device has exhausted its data capacity. After the I/O device has caught up, the DMA service is reestablished by a DREQ signal. During the interval between services, when the microprocessor is operating, the intermediate values of address and word count are stored in the VL82C37A Current Address and Current Word Count Registers. Only an EOP can cause an auto-initialize at the end of the service. EOP is generated either by TC or by an external signal.



The fourth mode cascades multiple VL82C37As together for easy system expansion. The HRQ and HLDA signals from additional VI 82C37As are connected to the DREQ and DACK signals of a channel of the primary VL82C37A. This permits the DMA requests of the additonal device to propagate through the priority network circuitry of the preceding device. The priority chain is not broken, and the new device waits for its turn to acknowledge requests. As the cascade channel of the primary VL82C37A is used only to prioritize the additional device, it does not produce any address or control signals of its own, which could conflict with the outputs of the active channel in the added device. The VL82C37A responds to the DREQ and DACK signal, but all other outputs except HRQ are disabled.

Figure 8 shows two devices cascaded into a primary device using two of the previous channels. This forms a twolevel DMA system. More VL82C37A's could be added at the second level by using the remaining channels of the first level. More devices can also be cascaded into the channels of the second-level devices, forming a third level.

#### TRANSFER TYPES

Each of the three modes of active transfer can perform three different types of transfers: read, write and verify. Write transfers move data from an I/O device to the memory by activating MEMW and IOR; read transfers move data from memory to an I/O device by activating MEMR and IOW.

Verify transfers are pseudo routines: the VL82C37A DMA Controller operates as in read or write transfers generating addresses, and responding to EOP, and other operations. The memory and I/O control lines remain inactive. The verify mode is not permitted during memory-tomemory operation.

To perform block moves of data from one memory address space to another with a minimum of programming, the VL82C37A includes a memory-tomemory transfer feature. Programming a bit in the Command Register selects channels 0 and 1 to operate as memoryto-memory transfer channels. The transfer is initiated by setting the software DREQ for channel 0. The VL82C37A requests a DMA device as usual. After HLDA is true, the device, using eight-state transfers in block transfer mode, reads data from the memory. The channel 0 Current Address Register is the source for the address, and is decremented or incremented as usual. The data byte read from the memory is then stored in the VL82C37A internal Temporary Register. Channel 1 writes the data from the Temporary Register to memory using the address in its Current Address Register and incrementing or decrementing it as usual. The channel 1 current word count is decremented. When the word count goes to FFFFH, a TC is generated causing an EOP output terminating the service.

Channel 0 may be programmed to hold the same address for all transfers, which permits a single word to be written to a block of memory.

The VL82C37A responds to external EOP signals during memory-to-memory transfers. In block search schemes data comparators may use this input on finding a match. The timing of memoryto-memory transfers is shown in Figure 10. Memory-to-memory operatons can be detected as an active AEN signal with no DACK outputs.

A channel may be set up to autoinitialize by setting a bit in the Mode Register. During nitialization, the original values of the Current Address and Current Word Count Registers are automatically restored from the Base Address and Base Word Count Registers of that channel following EOP. The base registers and the current registers are loaded at the same time. They remain unchanged thoughout the DMA service. The mask bit is not set when the channel is in auto-initialize. Following auto-initialize, the channel is prepared to perform another DMA service, without CPU action, as soon as a valid DREQ is detected.

The VL82C37A has two types of priority encoding available as softwareselectable options. The fixed priority option sets the channels in priority order based upon the descending value of their number. The channel with the lowest priority is 3, then 2,1 and the highest priority channel is 0. After recognizing any one channel for service, the other channels are prevented from interferring with that service until it is completed. In the rotating priority option, the last channel to get service becomes the lowest priority channel with the others rotating in order.

Rotating priority allows a single chip DMA system. Any device requesting service is guaranteed to be recognized after no more than three higher priority services have occurred. This prevents any one channel from dominating the system.

To achieve even greater throughput where system characteristics permit, the VL82C37A DMA Controller can compress the transfer time to two clock cycles. State S3 is used to extend the access time of the read pulse. By removing state S3, the read pulse width is made equal to the write pulse width, and a transfer consists only of state S2 to change the address and state S4 to perform the read/write. S1 state still occurswhen A8-A15 need updating (see the Address Generation section.)

To reduce pin count, the VL82C37A multiplexes the eight higher order address bits on the data lines. State S1 is used to output the higher order address bits to an external latch, where they may be placed on the address bus. The falling edge of the Address Strobe (ADSTB) is used to load these bits from the data lines to the latch. Address Enable (AEN) is used to enable the bits onto the address bus through a threestate enable. The lower order address bits are directly sent by the VL82C37A. Lines AO-A7 are connected to the address bus.

During block and demand transfer mode services, including multiple transfers, the addresses generated will be in order. During a large number of transfers the data held in the external address latch will not change. This data will change when a carry or borrow from A7 to A8 takes place in the normal order of addresses. To expedite transfers, the VL82C37A DMA Controller executes S1 states only when needed to update A8-A15 in the latch. For long services, S1 states and address strobes may occur only once every 256 transfers, a savings of 255 clock cycles for each 256 transfers.

#### **REGISTER DESCRIPTION**

Current Address Register: Each channel has a 16-bit Current Address Register. This register holds the value of the address used during DMA transfers.



The address is automatically incremented or decremented after each transfer and the intermediate values of the address are stored in the Current Address Register throughout the transfer. The microprocessor reads this register in successive 8-bit bytes. It may also be reinitialized by an autoinitialize to its original value which takes place only after an EOP.

Current Word Register: Each channel has a 16-bit Current Word Count Register that determines the number of transfers to be performed. The actual number of transfers is one more than the number programmed in the Current Word Count Register; programming a count of 100 will result in 101 transfers. The word count is decremented after each transfer; the intermediate value of this word count is stored in the register during the transfer. When the value in the register goes from 0 to FFFFH, a TC is generated. The register is then loaded or read in successive 8-bit bytes by the microprocessor in the program condition. Following the end of a DMA service, it may also be reinitialized by an auto-initialization to its original value which occurs only on EOP. If it is not auto-initialized, this register has a count of FFFFH after TC.

Base Address and Base Word Count Registers: Each channel has a pair of 16bit Base Address and Base Word Count Registers that store the orginal value of their associated current registers. Throughout auto-initialization these values are used to restore the current registers to their original values. The base registers are written at the same time with their corresponding current register in 8-bit bytes in the program condition by the microprocessor. These registers cannot be read by the microprocessor.

Command Register: This 8-bit register controls the operation of the VL82C37A, is programmed by the microprocessor in the program condition and is cleared by reset or a master clear instruction. Figure 2 lists and describes the function of the command bits.

Mode Register: All channels have a 6-bit Mode register. When the register is being written to by the microprocessor in the program condition, bits 0 to 1 determine which channel the Mode Register is to be written.

Request Register: The VL82C37A can responds to requests for DMA service that are initiated by software as well as by a DREQ signal. Each channel has a request bit associated with it in the 4-bit Request Register. These are nonmaskable and can be prioritized by the priority encoder network.

Each register bit is set or reset separately under software control, or is cleared upon generation of a TC or external EOP. The entire register is cleared by a Reset. To set or reset a bit, the software loads the correct form of the data word. Table 2 shows register address coding. To make a software request, the channel must be in block mode.

Mask Register: Each channel has an associated mask bit that can be set to disable the incoming DREQ signal. A mask bit is set when its associated channel produces an EOP, if the channel is not programmed for auto-initialize. Any bit of the 4-bit Mask register may also be set or cleared separately under software control. The entire register is set by a reset, which disables all DMA requests until a clear Mask Register instruction allows them to occur. This instruction to separately set or clear the mask bits is similar in form to that used with the Request Register.

Status Register: The Status Register is available to be read out of the VL82C37A DMA Controller by the microprocessor and contains information about the status of the devices at this point. This information includes which channels have reached a terminal count and which channels have pending DMA requests.

Bits 0-3 are set each time a TC is reached by that channel or an external EOP is applied and are cleared upon reset and on every status read. Bits 4 through 7 are set whenever their corresponding channel is requesting service.

Temporary Register: The Temporary Register is used to hold data during memory-to-memory transfers. The last word moved can be read by the microprocessor in the Program Condition following the completion of the transfers. The Temporary Register always contains the last byte transferred in the previous memory-tomemory operation, unless cleared by a reset.

Software Commands: These additional special software commands can be executed in the program condition and do not depend on any specific bit pattern on the data bus.

The clear first/last flip-flop command is executed prior to writing or reading new address or word count information to the VL82C37A. This initializes the flip-flop to a known state so that subsequent accesses to register contents by the microprocessor will address upper and lower bytes in the correct sequence.

The Master Clear software instruction has the same effect as the hardware reset. The Command, Status, Request, Temporary, and Internal First/Last Flip-Flop Registers are cleared and the Mask Register is set. The VL82C37A enters an idle cycle.

The Clear Mask Register command clears the mask bits of all four channels, enabling them to accept DMA requests.

#### PROGRAMMING

The VL82C37A DMA Controller accepts programming from the host processor any time that HLDA is inactive, even if the HRQ signal is active. The host must assure that programming and HLDA are mutually exclusive. A problem can occur if a DMA request occurs, on an unmasked channel while the VL82C37A is being programmed.

For example, the CPU may be starting to reprogram the two-byte Address Register of a channel when that channel receives a DMA request. If the VL82C37A is enabled (bit 2 in the command register is 0) and that channel is unmasked, a DMA service will occur after one byte of the Address Register has been reprogrammed. This can be avoided by disabling the controller - setting bit 2 in the command register - or masking the channel before programming another registers. Once the programming is complete, the controller can be enabled (unmasked).

After power-up all internal locations, including the Mode registers, should be loaded with a valid value. This should be done to unused channels as well.



### APPLICATION

Figure 1 shows a convenient method for configuring a DMA system with the VL82C37A DMA Controller and an 8080A/8085AH microprocessor system. Whenever there is at least one valid DMA request from a peripheral device, the multimode VL82C37A DMA Controller issues a HRQ to the processor. When the processor replies with a HLDA signal, the VL82C37A takes control of the address, data, and control buses. The address for the first transfer operation is output in two bytes - the least significant eight bits on the eight address outputs, and the most significant eight bits on the data bus. The contents of the data bus are then latched into the 8282 8-bit latch to complete the full 16 bits of the address bus. The 8282 is a high-speed, 8-bit, three-state latch in a 20-pin DIP package. After the initial transfer takes place, the latch is updated only after a carry or borrow is generated in the least significant address byte. Four DMA channels are available when one VL82C37A DMA Controller is used.



### FIGURE 1. SYSTEM INTERFACE



#### FIGURE 2. COMMAND REGISTER



#### FIGURE 3. MODE REGISTER

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | •     |                            | Bit Number                                                                            |
|---|---|---|---|---|---|---|---|-------|----------------------------|---------------------------------------------------------------------------------------|
|   |   |   |   |   |   |   |   |       |                            |                                                                                       |
| - |   |   |   |   |   |   |   | -     | 00<br>01<br>10<br>11       | Channel 0 Select<br>Channel 1 Select<br>Channel 2 Select<br>Channel 3 Select          |
|   |   |   |   |   |   |   |   | <br>- | 00<br>01<br>10<br>11<br>XX | Verify transfer<br>Write transfer<br>Read transfer<br>Illegal<br>If bits 6 and 7 = 11 |
|   |   |   | l |   |   |   |   | <br>  | 0<br>1                     | Autoinitialization disable<br>Autoinitialization enable                               |
|   |   | L |   |   |   |   |   | <br>  | 0<br>1                     | Address increment select<br>Address decrement selec                                   |
|   |   |   |   |   |   |   |   | <br>  | 00<br>01<br>10<br>11       | Demand mode select<br>Single mode select<br>Block mode select<br>Cascade mode select  |



#### FIGURE 4. REQUEST REGISTER

#### FIGURE 6. MASK REGISTER (SELECT MODE)





#### FIGURE 5. STATUS REGISTER





### **TABLE 2. REGISTER CODES**

|           |           |    |     | S   | ignals |    |            |    |
|-----------|-----------|----|-----|-----|--------|----|------------|----|
| Register  | Operation | CS | IOR | IOW | A3     | A2 | <b>A</b> 1 | A0 |
| Command   | Write     | 0  | 1   | 0   | 1      | 0  | 0          | 0  |
| Mode      | Write     | 0  | 1   | 0   | 1      | 0  | 1          | 1  |
| Request   | Write     | 0  | 1   | 0   | 1      | 0  | 0          | 1  |
| Mask      | Set/Reset | 0  | 1   | 0   | 1      | 0  | 1          | 0  |
| Mask      | Write     | 0  | 1   | 0   | 1      | 1  | 1          | 1  |
| Temporary | Read      | 0  | 0   | 1   | 1      | 1  | 0          | 1  |
| Status    | Read      | 0  | 0   | 1   | 1      | 0  | 0          | 0  |



### **TABLE 3. SOFTWARE COMMAND CODES**

|                |    | Sigr |     |     |     |                                |
|----------------|----|------|-----|-----|-----|--------------------------------|
| A3             | A2 | A1   | A0  | IOR | IOW | Operation                      |
| 1              | 0  |      | 0   | 0   | 1   | Read Status Register           |
| 1              | 0. | 0    | . O | 1   | 0   | Write Command Register         |
| ` <b>`1</b>    | 0  | · 0  | 1   | · 0 | · 1 | Illegal                        |
| 1              | 0  | 0    | 1   | 1   | 0   | Write Request Register         |
| <sup>:</sup> 1 | 0  | 1    | 0   | 0   | 1   | llegal                         |
| . 1            | 0  | 1    | 0   | 1   | 0   | Write Single Mask Register Bit |
| 1              | 0  | 1    | 1   | 0   | 1   | Illegal                        |
| 1              | 0  | 1    | 1   | 1   | 0   | Write Mode Register            |
| 1              | 1  | 0    | 0   | 0   | 1   | lllegal                        |
| 1              | 1  | 0    | 0   | 1   | 0   | Clear Byte Pointer Flip/Flop   |
| 1              | 1  | o    | 1   | 0   | 1   | Read Temporary Register        |
| . 1            | 1  | 0    | 1   | 1   | 0   | Master Clear                   |
| 1              | 1  | 1    | 0   | . 0 | 1   | Illegal                        |
| 1              | 1  | . 1  | 0   | 1   | 0   | Clear Mask Register            |
| 1              | 1  | 1    | 1   | 0   | 1   | Illegal                        |
| 1              | 1  | 1    | 1   | 1   | 0   | Write All Mask Register Bits   |

#### FIGURE 8. CASCADED VL82C37A CONTROLLERS



4-158



## TABLE 4. WORD COUNT AND ADDRESS REGISTER COMMAND CODES

|         |                             |           | Signals |     |        |    |        |            |        | Internal  | Data Bus        |
|---------|-----------------------------|-----------|---------|-----|--------|----|--------|------------|--------|-----------|-----------------|
| Channel | Register                    | Operation | CS      | IOR | IOW    | A3 | A2     | <b>A</b> 1 | A0     | Flip-Flop | DB0-DB7         |
|         | Base and Current Address    | Write     | 0       | 1   | 0      | 0  | 0      | 0          | 0      | 0         | A0-A7           |
|         |                             |           | 0       | 1   | 0      | 0  | 0      | 0          | 0      | 1         | A8-A15          |
|         | Current Address             | Read      | 0       | 0   | 1      | 0  | 0      | 0          | 0      | 0         | A0-A7           |
| 0       |                             |           | 0       | 0   | 1      | U  | U      | U          | U      | i         | A8-A15          |
|         | Base and Current Word Count | Write     | 0       | 1   | 0      | 0  | 0      | 0          | 1      | 0         | W0-W7           |
|         |                             |           | ľ       |     | Ū.     | Ŭ  | Ŭ      | v          |        |           |                 |
|         | Current Word Count          | Read      | 0       | 0   | 1      | 0  | 0      | 0          | 1      | 0         | W0-W7<br>W8-W15 |
|         | Base and Current Address    | Write     |         |     |        |    |        |            |        |           | A0-A7           |
|         | Dase and Current Address    | VVIILE    | 0       | 1   | 0<br>0 | o  | 0      | 1          | 0      | 1         | A8-A15          |
|         | Current Address             | Read      | 0       | 0   | 1      | 0  | 0      | 1          | 0      | 0         | A0-A7           |
| 1       | ,                           |           | Ō       | 0   | 1      | 0  | 0      | 1          | 0      | 1         | A8-A15          |
| I       | Base and Current Word Count | Write     | 0       | 1   | 0      | 0  | 0      | 1          | 1      | 0         | W0-W7           |
|         |                             |           | 0       | 1   | 0      | 0  | 0      | 1          | 1      | 1         | W8-W15          |
|         | Current Word Count          | Read      | 0       | 0   | 1      | 0  | 0      | 1          | 1      | 0         | W0-W7           |
|         |                             |           | 0       | 0   | 1      | 0  | 0      | 1          | 1      | 1         | W8-W15          |
|         | Base and Current Address    | Write     | 0       | 1   | 0      | 0  | 1      | 0          | 0      | 0         | A0-A7           |
|         |                             |           | ľ       |     | Ŭ      | Ŭ  |        | ,          | v      |           |                 |
|         | Current Address             | Read      | 0       | 0   | 1      | 0  | 1      | 0          | 0      | 0         | A0-A7<br>A8-A15 |
| 2       | Base and Current Word Count | Write     |         | 1   | 0      | 0  | 1      | 0          | 4      | 0         | W0-W7           |
|         | Base and current word count | Vinco     | ŏ       | 1   | ŏ      | ŏ  | 1      | õ          | 1      | 1         | W8-W15          |
|         | Current Word Count          | Read      | 0       | 0   | 1      | 0  | 1      | 0          | 1      | 0         | W0-W7           |
|         |                             |           | 0       | 0   | 1      | 0  | 1      | 0          | 1      | 1         | W8-W15          |
|         | Base and Current Address    | Write     | 0       | 1   | 0      | 0  | 1      | 1          | 0      | . 0       | A0-A7           |
|         |                             |           | 0       | 1   | 0      | 0  | 1      | 1          | 0      | 1         | A8-A15          |
|         | Current Address             | Read      | 0       | 0   | 1      | 0  | 1      | 1          | 0      | 0         | A0-A7           |
| 3       | · · · ·                     |           |         | U   | 1      | U  | 1      | 1          | U      |           | A8-A15          |
|         | Base and Current Word Count | Write     | 0       | 1   | 0<br>0 | 0  | 1      | 1          | 1      | 0         | W0-W7<br>W8-W15 |
|         |                             | Duri      |         |     | -      | •  |        |            |        |           | 1410 1417       |
|         | Current word Count          | Read      | 0       | 0   | 1      | 0  | 1<br>1 | 1          | 1<br>1 | 1         | W0-W7<br>W8-W15 |
|         |                             |           |         |     |        |    |        |            |        |           | 1               |



### TABLE 5. DMA MODE AC CHARACTERISTICS TA = 0°C to +70°C, VCC = 5 V ±5%

| Olim had | Davamatar                                       | VL82C3  | 7A-04 | VL82C3  | 7A-05 | VL82C37A-08 |     | Linit |  |
|----------|-------------------------------------------------|---------|-------|---------|-------|-------------|-----|-------|--|
| Symbol   |                                                 | Min     | Max   | Min     | Max   | Min         | Max |       |  |
| TAEL     | AEN HIGH from CLK LOW (S1) Delay Time           |         | 225   |         | 200   |             | 105 | ns    |  |
| TAET     | AEN LOW from CLK HIGH (S1) Delay Time           |         | 150   |         | 130   |             | 80  | ns    |  |
| TAFAB    | ADR Active to Float Delay from CLK HIGH         |         | 120   |         | 90    |             | 55  | ns    |  |
| TAFC     | Read or Write Float from CLK HIGH               |         | 120   |         | 120   |             | 75  | ns    |  |
| TAFDB    | DB Active Float Delay from CLKHIGH              |         | 190   |         | 170   |             | 135 | ns    |  |
| TAHR     | ADR from Read HIGH Hold Time                    | TCY-100 |       | TCY-100 |       | TCY-75      |     | ns    |  |
| TAHS     | DB from ADSTB LOW Hold Time                     | 40      |       | 30      |       | 20          |     | ns    |  |
| TAHW     | ADR from Write HIGH Hold Time                   | TCY-50  |       | TCY-50  |       | TCY-50      |     | ns    |  |
|          | DACK Valid from CLK LOW Delay Time (Note 7)     |         | 220   |         | 170   |             | 105 | ns    |  |
| ТАК      | EOP HIGH from CLK HIGH Delay Time (Note 10)     |         | 190   |         | 170   |             | 105 | ns    |  |
|          | EOP LOW from CLK HIGH Delay Time                |         | 190   |         | 170   | -           | 105 | ns    |  |
| TASM     | ADR Stable from CLK HIGH                        |         | 190   |         | 170   |             | 105 | ns    |  |
| TASS     | DB to ADSTB LOW Setup Time                      | 100     |       | 100     |       | 65          |     | ns    |  |
| тсн      | Clock HIGH Time (Transitions ≤ 10 ns)           | 100     |       | 80      |       | 55          |     | ns    |  |
| TCL      | Clock LOW Time (Transitions ≤ 10 ns)            | 110     |       | 68      |       | 43          | + ( | ns    |  |
| TCY      | CLK Cycle Time                                  | 250     |       | 200     |       | 125         |     | ns    |  |
| TDCL     | CLK HIGH to Read or Write LOW Delay (Note 4)    |         | 200   |         | 190   | 1           | 120 | ns    |  |
| TDCTR    | Read HIGH from CLK HIGH (S4)Delay Time (Note 4) |         | 210   |         | 190   |             | 115 | ns    |  |
| TDCTW    | Write HIGH from CLK HIGH (S4) Delay (Note 4)    |         | 150   |         | 130   |             | 80  | ns    |  |
| TDQ1     | HPO Valid from CLK HIGH Dolov Time (Note 5)     |         | 120   |         | 120   |             | 75  | ns    |  |
| TDQ2     |                                                 |         | 190   |         | 120   |             | 75  | ns    |  |
| TEPS     | EOP LOW from CLK LOW Setup Time                 | 45      |       | 40      |       | 25          |     | ns    |  |
| TEPW     | EOP Pulse Width                                 | 225     |       | 220     |       | 135         |     | ns    |  |
| TFAAB    | ADR Float to Active Delay from CLKHIGH          |         | 190   |         | 170   | [           | 100 | ns    |  |
| TFAC     | Read or Write Active from CLK HIGH              |         | 150   |         | 150   |             | 90  | ns    |  |
| TFADB    | DB Float to Active Delay from CLK HIGH          |         | 225   |         | 200   |             | 110 | ns    |  |
| THS      | HLDA Valid to CLK HIGH Setup Time               | 75      |       | 75      |       | 45          |     | ns    |  |
| TIDH     | Input Data from MEMR HIGH Hold Time             | 0       |       | 0       |       | 0           |     | ns    |  |
| TIDS     | Input Data to MEMR HIGH Setup Time              | 190     |       | 170     |       | 90          |     | ns    |  |
| TODH     | Output Data from MEMW HIGH Hold Time            | 20      |       | 10      |       | 10          |     | ns    |  |
| TODV     | Output Data Valid to MEMW HIGH                  | 125     |       | 125     |       | 90          |     | ns    |  |
| TQS      | DREQ to CLK LOW (S1,S4) Setup Time              | 0       |       | 0       |       | 0           |     | ns    |  |
| TRH      | CLK to READY LOW Hold Time                      | 20      |       | 20      |       | 20          |     | ns    |  |
| TRS      | READY to CLK LOW Setup Time                     | 60      |       | 60      |       | 35          |     | ns    |  |
| TSTL     | ADSTB HIGH from CLK HIGH Delay Time             |         | 150   |         | 130   |             | 110 | ns    |  |
| TSTT     | ADSTB LOW from CLK HIGH Delay Time              |         | 110   |         | 90    |             | 65  | ns    |  |

Explanatory notes follow DC Characteristics Table.



### FIGURE 9. DMA TRANSFER TIMING (SEE TABLE 5.)





#### FIGURE 10. MEMORY-TO-MEMORY TRANSFER TIMING (SEE TABLE 5)





| TABLE 6. PERIPHERAL M | IODE AC ( | CHARACTERISTICS | TA = 0°C to +70°C, VCC = 5 V $\pm$ 5% |
|-----------------------|-----------|-----------------|---------------------------------------|
|-----------------------|-----------|-----------------|---------------------------------------|

|        |                                           |      | 37 <b>A-0</b> 4 | VL82C | 37A-05 | VL82C37A-08 |     | Unit |
|--------|-------------------------------------------|------|-----------------|-------|--------|-------------|-----|------|
| Symbol | Parameter                                 | Min  | Max             | Min   | Max    | Min         | Max |      |
| TAR    | ADR Valid or CS LOW to Read LOW           | 50   |                 | 50    |        | 30          |     | ns   |
| TAW    | ADR Valid to Write HIGH Setup Time        | 150  |                 | 130   |        | 80          |     | ns   |
| TCW    | CS LOW to Write HIGH Setup Time           | 150  |                 | 130   |        | 80          |     | ns   |
| TDW    | Data Valid to Write HIGH Setup Time       | 150  |                 | 130   |        | 80          |     | ns   |
| TRA    | ADR or CS Hold from Read HIGH             | 0    |                 | 0     |        | 0           |     | ns   |
| TRDE   | Data Access from Read LOW (Note 3)        |      | 200             |       | 140    |             | 120 | ns   |
| TRDF   | DB Float Delay from Read HIGH             | 20   | 100             | 0     | 70     | 0           | 70  | ns   |
| TRSTD  | Power Supply HIGH to RESET LOW Setup Time | 500  |                 | 500   |        | 500         |     | ns   |
| TRSTS  | RESET to First IOW                        | 2TCY |                 | 2TCY  |        | 2TCY        |     | ns   |
| TRSTW  | RESET Pulse Width                         | 300  |                 | 300   |        | 300         |     | ns   |
| TRW    | Read Width                                | 250  |                 | 200   |        | 155         |     | ns   |
| TWA    | ADR from Write HIGH Hold Time             | 20   |                 | 20    |        | 10          |     | ns   |
| TWC    | CS HIGH from Write HIGH Hold Time         | 20   |                 | 20    |        | 10          |     | ns   |
| TWD    | Data from Write HIGH Hold Time            | 30   |                 | 30    |        | 20          |     | ns   |
| TWWS   | Write Width                               | 200  |                 | 160   |        | 100         |     | ns   |

Explanatory notes follow DC Characteristics Table.

FIGURE 11. SLAVE MODE WRITE TIMING (SEE TABLE 6)





#### FIGURE 12. SLAVE MODE READ TIMING (SEE TABLE 6)



FIGURE 13. READY TIMING (SEE TABLE 5)





FIGURE 14. COMPRESSED TRANSFER TIMING (SEE TABLE 5)



FIGURE 15. RESET TIMING (SEE TABLE 6)

6





### **ABSOLUTE MAXIMUM RATINGS**

| -0.5 to 7.0 V   |
|-----------------|
| -0.5 to 5.5 V   |
| -0.5 to 5.5 V   |
| 0 °C to +150°C  |
| -65°C to +150°C |
|                 |

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 may affect device reliability.

| Symbol | Parameter              | Min     | Тур (1) | Max       | Unit   | Test Conditions                                                                                       |
|--------|------------------------|---------|---------|-----------|--------|-------------------------------------------------------------------------------------------------------|
| VOH    | Output HIGH Voltage    | 2.4     |         |           | V      | IOH = -200 μA                                                                                         |
|        |                        | 3.3     | 1 - A   |           | V      | $IOH = -100 \mu A (HRQ Only)$                                                                         |
| VOL    | Output LOW Voltage     |         |         | 450       | mV     | IOL = 2.0 mA (data bus) EOP<br>IOL = 3.2 mA (other outputs) (Note 8)<br>IOL = 2.5 mA (ADSTB) (Note 8) |
| VIH    | Input HIGH Voltage     | 2.2     |         | VCC + 0.5 | V      |                                                                                                       |
| VIL    | Input LOW Voltage      | -0.5    |         | 0.8       | v      |                                                                                                       |
| ILI    | Input Load Current     |         |         | ±10       | μA     | $0 V \le VIN \le VCC$                                                                                 |
| ILO    | Output Leakage Current | *       |         | ±10       | μA     | 0.45 V ≤ VOUT ≤ VCC                                                                                   |
| ICC    | VCC Supply Current     |         | 110     | 130       | mA/MHz | TA = + 25°C                                                                                           |
| CO     | Output Capacitance     |         | 4       | 8         | pF     |                                                                                                       |
| C1     | Input Capacitance      |         | 8       | 15        | pF     | FC = 1.0 MHz, Inputs = 0 V                                                                            |
| C10    | I/O Capacitance        | · · · · | 10      | 18        | pF     |                                                                                                       |

### DC CHARACTERISTICS TA = 0°C to +70°C, VCC = 5 V ±5%

AC and DC Characteristics Notes:

- 1. Typical values are for TA = 25°C, nominal supply voltage, and nominal processing parameters.
- 2. Input timing parameters assume transition times of 20 ns or less. Waveform measurement points for both input and output signals are 2.0 V for high and 0.8 V for low, unless otherwise noted.
- 3. Output loading is 1 TTL gate plus 150 pF capacitance, unless otherwise noted.
- 4. The net IOW or MEMW pulse width for normal write will be TCY-100 ns and for extended write will be 2TCY-100 ns. The net IOR or MEMR pulse width for normal read will be 2TCY-50 ns and for compressed read will be TCY-50 ns.
- 5. TDQ is specified for two different output high levels: TDQ1 is measured at 2.0 V, TDQ2 is measured at 3.3 V. The value for TDQ2 assumes an external 3.3 Kohm pull-up resistor connected from HRQ to VCC.
- 6. DREQ should be held active until DACK is returned.
- 7. DREQ and DACK signals may be active high or active low. Timing diagrams assume the active high mode.
- Successive read and/or write operations, by the external processor, to program or examine the controller must be timed to allow at least 500 ns for the VL82C37A-04, at least 400 ns for the VL82C37A-05 and at least 250 ns for the VL82C37A-08, as recovery time between active read or write pulses.
- 9. EOP is an open-collector output. This parameter assumes the presence of a 2.2 Kohm pull-up resistor to VCC.
- 10.Pin 5 is an input that should always be at a logic high level. An internal pull-up resistor will establish a logic high when the pin is left floating. It is recommended, however, that pin 5 be tied to VCC.



## PROGRAMMABLE INTERVAL TIMER

### FEATURES

- Compatible 8080A, 8085A, 8086, 8088, and similiar microprocessors
- Counts in binary or BCD
- Clock inputs from dc to maximum clock operating frequency
- Status may be read back on command
- · Single 5 V power supply
- Three independent 16-bit counters
- Six programmable counter modes
- Low power consuming CMOS technology

### **PIN DIAGRAM**



### DESCRIPTION

The VL82C54 is a CMOS programmable interval timer/counter designed for use with Intel-type microcomputer systems. It is a general-purpose, multi-timing element that can be considered as three separate counters by the system software.

The VL82C54 solves the problem of generating an accurate timing interval in the microprocessor-based system. Instead of setting up timing loops in software, the programmer configures the VL82C54 to generate the timing

intervals required by the system. At the termination of the delay, the VL82C54 generates an interrupt to the CPU. The overhead software is minimal, and variable lengths are easily programmed.

In addition to the three independent 16bit counters on the VL82C54, it also has its own 8-bit data bus, two address lines, a chip select, and individual read and write control lines.

The VL82C54 is available in 8 MHz and 10 MHz maximum clock frequencies.

### **BLOCK DIAGRAM**



| ORDER INFORMATION |                    |                             |  |  |  |  |  |
|-------------------|--------------------|-----------------------------|--|--|--|--|--|
| Part<br>Number    | Clock<br>Frequency | Package                     |  |  |  |  |  |
| VL82C54-08PC      |                    | Plastic DIP                 |  |  |  |  |  |
| VL82C54-08QC      | 8 MHz              | Plastic Leaded Chip Carrier |  |  |  |  |  |
| VL82C54-08CC      |                    | Ceramic DIP                 |  |  |  |  |  |
| VL82C54-10PC      |                    | Plastic DIP                 |  |  |  |  |  |
| VL82C54-10QC      | 10 MHz             | Plastic Leaded Chip Carrier |  |  |  |  |  |
| VL82C54-10CC      |                    | Ceramic DIP                 |  |  |  |  |  |



## **PROGRAMMABLE INTERRUPT CONTROLLER**

### FEATURES

- Compatible with 8086, 8088, and similiar microprocessors
- Low power consuming CMOS
- · Interrupt modes are programmable.
- Minimizes software overhead.
- · Eight prioritized control levels
- 64 levels of expandability
- Single 5 V power supply
- 28-pin DIP

### DESCRIPTION

The VL82C59A Programmable Interrupt Controller can manage up to eight vectored priority interrupts for the system's CPU. It can be cascaded to handle up to 64 interrupts. No additional circuitry is required.

The VL82C59A is designed to relieve the software of the burden of handling multilevel priority interrupts. It controls several modes, permitting optimization for a large number of system needs. The VL82C59A is fully upwardcompatible with the HMOS 8259 or 8259A. Software originally written for the HMOS 8259 or 8259A will operate the VL82C59A in all 8259- or 8259A- equivalent modes.

It is housed in a 28-pin DIP, uses CMOS technology, and requires a single 5 V supply. The circuit is totally static, requiring no clock input.

### **PIN DIAGRAM**

## BLOCK DIAGRAM





| ORDER INFORMATION                                                |              |                                                           |  |  |  |  |
|------------------------------------------------------------------|--------------|-----------------------------------------------------------|--|--|--|--|
| Part<br>Number                                                   | Bus<br>Speed | Package                                                   |  |  |  |  |
| VL82C59A-08PC<br>VL82C59A-08QC                                   | 8 MHz        | Plastic DIP<br>Plastic Leaded Chip Carrier                |  |  |  |  |
| VL82C59A-08CC<br>VL82C59A-10PC<br>VL82C59A-10QC<br>VL82C59A-10QC | 10 MHz       | Ceramic DIP<br>Plastic DIP<br>Plastic Leaded Chip Carrier |  |  |  |  |



## **CLOCK GENERATOR AND DRIVER**

### FEATURES

- Two maximum clock frequencies available:
   - 8 MHz (VL82C84A-08)
   -10 MHz (VL82C84A-10)
- Local READY is provided, as well as Multibus<sup>®</sup> READY synchronization
- Schmitt-trigger input generates
   system RESET output
- Clock generator supports the 8086, 8088, and other similiar processors
- Capable of clock synchronization with other VL82C84A devices
- Crystal or TTL input may be used as a frequency source
- 100 mW maximum power dissipation

**PIN DIAGRAM** 

### DESCRIPTION

The VL82C84A is a single-chip clock generator/driver for the 8086, 8088, and similiar processors. The device contains a crystal-controlled oscillator and a divide-by-three counter, as well as complete synchronization and reset logic. Handling all of these functions on a single device allows the VL82C84A to significantly reduce the chip count in a system, while enhancing reliability, production ease, and increasing mean time between failure (MTBF).

Fabricated in low-power CMOS, the VL82C84A provides a convenient way to decrease power consumption of the system. Fully compatible with existing designs using the NMOS 8284A, the VL82C84A provides a low-power costeffective solution.

The output drivers of the VL82C84A offer the driving capability of the conventional HMOS device. As a result, they do not require any external drivers.

The VL82C84A is compatible with all the other members of the VL82CXX family of microprocessor peripherals. Offering higher performance and lower power consumption than previously available 82CXX peripherals, these devices offer CMOS advantages to 8086, 8088, and similiar systems.

## BLOCK DIAGRAM





| ORDER INFORMATION |                    |                             |  |  |  |  |  |
|-------------------|--------------------|-----------------------------|--|--|--|--|--|
| Part<br>Number    | Clock<br>Frequency | Package                     |  |  |  |  |  |
| VL82C84A-08PC     |                    | Plastic DIP                 |  |  |  |  |  |
| VL82C84A-08QC     | 8 MHz              | Plastic Leaded Chip Carrier |  |  |  |  |  |
| VL82C84A - 08CC   |                    | Ceramic DIP                 |  |  |  |  |  |
| VL82C84A-10PC     |                    | Plastic DIP                 |  |  |  |  |  |
| VL82C84A-10QC     | 10 MHz             | Plastic Leaded Chip Carrier |  |  |  |  |  |
| VL82C84A-10CC     |                    | Ceramic DIP                 |  |  |  |  |  |

Multibus<sup>®</sup> is a registered trademark of Intel Corporation.

# VL82C88 PRODUCT BRIEF



## **CMOS BUS CONTROLLER**

### FEATURES

- Compatible with 8086, 8088 and similiar microprocessors
- · Three-state command output drivers
- Low-power CMOS technology
- Fully compatible with HMOS 8288
- Advanced commands provided
- Wide flexibility in system configurations
- Can be used with an I/O bus
- Interface to up to two multi-master buses

11 TOWC

Single 5 V power supply

## PIN DIAGRAM

GND 110

### DESCRIPTION

The VL82C88 Bus Controller is a CMOS device intended for use with medium-to-large 8086- and 8088-type microprocessor-based systems. The bus controller provides command and control timing generation, as well as bus drive capability, for optimizing system performance. The VL82C88 decodes the three status lines from the system microprocessor to generate the command and control signals at the specified time.

The VL82C88 bus controller generates commands in two ways:

I/O Bus Mode - The VL82C88 is in the I/O Bus mode if the IOB pin is tied HIGH. In the I/O Bus mode, all I/O command lines (IORC, IOWC, AIOWC, INTA) are always enabled.

System Bus Mode - The VL82C88 is in the System Bus mode if the IOB pin is tied LOW. In this mode, no command is issued until 115 ns after the AEN Line is activated.

The 20-pin, low-power-consuming, CMOS VL82C88 is available in 8 MHz and 10 MHz clock frequencies.





| ORDER INFORMATION |                    |                             |  |  |  |  |  |  |  |
|-------------------|--------------------|-----------------------------|--|--|--|--|--|--|--|
| Part<br>Number    | Clock<br>Frequency | Package                     |  |  |  |  |  |  |  |
| VL82C88-08PC      |                    | Plastic DIP                 |  |  |  |  |  |  |  |
| VL82C88-08QC      | 8 MHz              | Plastic Leaded Chip Carrier |  |  |  |  |  |  |  |
| VL82C88-08CC      |                    | Ceramic DIP                 |  |  |  |  |  |  |  |
| VL82C88-10PC      |                    | Plastic DIP                 |  |  |  |  |  |  |  |
| VL82C88-10PC      | 10 MHz             | Plastic Leaded Chip Carrier |  |  |  |  |  |  |  |
| VL82C88-10CC      |                    | Ceramic DIP                 |  |  |  |  |  |  |  |

Multibus<sup>®</sup> is a registered trademark of Intel Corp.



## **CMOS CLOCK GENERATOR AND CONTROLLER**

### FEATURES

- Two independent 20 MHz oscillators generate two 10 MHz clock outputs and one 20 MHz clock output.
- Oscillator input frequency sources can be either crystals or external oscillators.
- Outputs directly drive the Z80, Z8000, 8086, 8088, and 68000 microprocessor clock inputs.
- Can be used as a general-purpose clock generator.
- Single 5 V power required
- Provides ability to stretch high and/or low phase of clock signa under external control.
- · On-chip reset logic

### **PIN DIAGRAM**

| VL85C81 |   |                         |    |   |       |  |  |  |  |  |
|---------|---|-------------------------|----|---|-------|--|--|--|--|--|
|         | 1 | $\overline{\mathbf{v}}$ | 18 | þ | RSTI  |  |  |  |  |  |
| XTL1B 🗆 | 2 |                         | 17 | þ | RSTO  |  |  |  |  |  |
|         | 3 |                         | 16 | þ | osc   |  |  |  |  |  |
|         | 4 |                         | 15 | þ | ZCLK  |  |  |  |  |  |
|         | 5 |                         | 14 | Ь | GND   |  |  |  |  |  |
| ADD1    | 6 |                         | 13 | þ | TCLK  |  |  |  |  |  |
| ADD2    | 7 |                         | 12 | Þ | XTL2A |  |  |  |  |  |
| STRT C  | 8 |                         | 11 | 白 | XTL2B |  |  |  |  |  |
| C0 🗆    | 9 |                         | 10 | þ | C1    |  |  |  |  |  |
| 2       |   |                         |    | - |       |  |  |  |  |  |

### DESCRIPTION

The VL85C81 Clock Generator and Controller is a versatile addition to VLSI's family of "instant ASIC" application-specific logic products. The selective clock-stretching capabilities and variety of timing outputs produced by this device allow it to easily meet the timing design requirements of systems with microprocessors and peripheral devices. The clock output drivers of the VL85C81 also meet the non-TTL voltage requirements for driving NMOS clock inputs with no additional external components. The VL85C81 provides an elegant, single-chip solution to the design of system clocks for

microprocessor-based products. The VL85C81 oscillators are referenced to the system clock oscillator and the general-purpose clock oscillator. Both oscillators are driven by external crystals or other frequency sources.

A Reset output on the clock generator allows the VL85C81 system clock output to be synchronized with an incoming reset to the VL85C81. The external reset initiates the Reset output or system reset for a minimum of 30 ms, allowing a "power-up" system initialization.



### **ORDER INFORMATION**

| Part<br>Number | Clock<br>Frequency | Package                     |
|----------------|--------------------|-----------------------------|
| VL85C81-05PC   |                    | Plastic DIP                 |
| VL85C81-05QC   | 5 MHz              | Plastic Leaded Chip Carrier |
| VL85C81-05CC   |                    | Ceramic DIP                 |
| VL85C81-08PC   |                    | Plastic DIP                 |
| VL85C81-08QC   | 8 MHz              | Plastic Leaded Chip Carrier |
| VL85C81-08CC   |                    | Ceramic DIP                 |





| , |       |
|---|-------|
|   |       |
|   |       |
|   |       |
|   |       |
|   |       |
|   |       |
|   |       |
|   |       |
|   |       |
|   |       |
|   |       |
|   |       |
|   |       |
|   |       |
|   |       |
|   |       |
|   |       |
|   |       |
|   |       |
|   |       |
|   |       |
|   |       |
|   | ····· |
|   |       |
|   |       |
|   |       |
|   |       |
|   |       |
|   |       |
|   |       |
|   |       |
|   |       |
|   |       |
|   |       |

## SECTION 5 DIGITAL SIGNAL PROCESSING PRODUCTS

Application Specific Logic Products Division

정도를 감독할 수 다니는 1993년 - 1993년 - 1993년 - 1993년 대한 일반 방법 전 1993년 대한 2015년 - 1993년 - 1993년

. 然后的正正的 的复数形式 上的情况 在的特别部分 Charlense

# VL2010



## **16 x 16 PARALLEL MULTIPLIER-ACCUMULATOR**

### FEATURES

- 16 X 16 parallel multiplication and product accumulation
- High speed Multiply-accumulate time: VL2010-65 50 ns typ 65 ns max VL2010-90 65 ns typ 90 ns max
- CMOS silicon-gate technology
- Low power; 0.2 W typical (VL2010-90)
- Single 5 V supply
- Standard TTL-compatible I/O levels
- Performs double-precision subtraction, addition, and multiplication, including rounding control
- Pin-for-pin functional replacement for WTL1010, WTL2010, TRW TDC1010J, LMA1010, and AMD 29510
- Available in 64-pin ceramic DIP, and soon to be available in plastic DIP, Plastic Leaded Chip Carrier, and Pin Grid Array

### DESCRIPTION

The VL2010 is a 16 X 16 parallel multiplier-accumulator (MAC) fabricated using CMOS silicon-gate technology. The VL2010 offers ultralow power and very high performance. The high performance is achieved through the use of the efficient Booth's algorithm and advanced VLSI processing technology.

The VL2010 operates from a single five volt supply and is compatible with standard TTL logic levels. The VL2010 is a pin-for-pin functional replacement for the WTL1010, WTL 2010, TRW TDC1010J or AMD 29510.

The VL2010, under control of the ACC input (see Block Diagram), performs either the multiply only, or the multiplyaccumulate function. In either mode, input data X and Y can be specified as two's complement or unsigned magnitude. Input data representation is selectable via the input control line TC. In the multiply-only mode, extended product (XTP) data is signextended or set to zero for two's complement and unsigned-magnitude arithmetic, respectively. Additionally, a RND control is available for rounding up the most significant product (MSP) and extended product (XTP) data. In the multiply-accumulate mode, the double-precision accumulated answer is rounded back to single-precision or single-precision plus XTP bits.

The VL2010 architecture includes input and output data registers, as well as 3-state output data buses with independent, non-registered control. Time-multiplexing is used for the common Least Significant <u>Product</u> (LSP) and Input Data (Y) I/O lines. Input lines TSX, TSM, and TSL, respectively, control the outputs of the XTP, MSP, and LSP registers.

In the multiply-accumulate mode (ACC active), output data can be added to or subtracted from the last product. When SUB is also active, subtraction is performed. Otherwise, addition is performed.

The VL2010 can be efficiently applied in a variety of digital signal processing functions, including digital filtering (recursive, non-recursive, wave) and FFT processing (complex multiplication, butterfly computation). In addition, the VL2010 can be employed effectively in upgrading the computational capability of mini- and microcomputer systems.

### **ORDER INFORMATION**

| Part<br>Number | Multiply/<br>Accumulate<br>Time | Package        |
|----------------|---------------------------------|----------------|
| VL2010-65CC    |                                 | Ceramic DIP    |
| VL2010-65PC    |                                 | Plastic DIP    |
| VL2010-65QC    | 65ns                            | PLCC           |
| VL2010-65GC    |                                 | Pin Grid Array |
| VL2010-90CC    |                                 | Ceramic DIP    |
| VL2010-90PC    |                                 | Plastic DIP    |
| VL2010-90QC    | 90ns                            | PLCC           |
| VL2010-90GC    |                                 | Pin Grid Array |

### **BLOCK DIAGRAM**





### **PIN DESCRIPTIONS**

### X

Data Input

X is a 16-bit input. Data bits are loaded on the rising edge of CLKX.

#### Y/LSP

Data input/

#### Data Output

These pins share functions between Y (16-bit data input) and LSP (least significant product output). Input data bits are loaded on the rising edge of CLKY. Output LSP data bits are available following the rising edge of CLKP.

#### MSP

#### **Data Output**

The 16-bit most-significant product output. MSP data is available following the rising edge of CLKP.

#### CLKX, CLKY Input Clocks

These X and Y data input register clocks are active on their rising edges.

#### ACC

#### Accumulate

A HIGH level input permits the contents of the LSP, MSP, and XTP registers to be added to the multiplier output. A LOW level input allows multiplication only. The ACC signal is loaded on the rising edge of either CLKX or CLKY, and must be valid for the entire duration of input data.

### SUB

### Subtract

When ACC and SUB are both HIGH, the contents of the output register are subtracted from the last product generated, and the difference is stored back into the output registers at the rising edge of the next CLKP. When ACC is HIGH and SUB is LOW, addition instead of subtraction is performed. The SUB signal is loaded into the SUB register at the rising edge of either CLKX or CLKY.

The SUB signal must be valid over the same period that the input data is valid. When ACC is LOW, SUB is a "Don't Care" pin.

## RND

#### Round

A HIGH-level input causes a "1" to be added to the most significant bit of the LSP to round up MSP and XTP data. RND is loaded on the rising edge of either CLKX or CLKY and must be valid for the duration of the input data.

#### тс

#### Two's Complement/ Unsigned Magnitude

A HIGH-level input defines X and Y as two's complement data, while a LOW level defines the input data as unsigned magnitude. As with ACC, SUB, and RND, TC is loaded at the rising edge of either CLKX or CLKY and must be valid for the duration of the input data.

#### TSX,TSM,TSL 3-state Output Controls

The LSP, MSP, or XTP output buffers are at high-impedance (output disabled) when TSL, TSM, or TSX, respectively, is HIGH. These are direct, nonregistered control signals. The output drivers are enabled when TSL, TSM, or TSX is LOW.

## PRELOAD TRUTH TABLE

| PREL | TSX | TSM | TSL | ХТР  | MSP  | LSP  |
|------|-----|-----|-----|------|------|------|
| 0    | 0   | 0   | 0   | Q    | Q    | Q    |
| 0    | 0   | 0   | 1   | Q    | Q    | Hi-Z |
| 0    | 0   | 1   | 0   | Q    | Hi-Z | Q    |
| 0    | 0   | 1   | 1   | Q    | Hi-Z | Hi-Z |
| 0    | 1   | 0   | 0   | Hi-Z | Q    | Q    |
| 0    | 1   | 0   | 1   | Hi-Z | Q    | Hi-Z |
| 0    | 1   | 1   | 0   | Hi-Z | Hi-Z | Q    |
| Ó    | 1   | 1   | 1   | Hi-Z | Hi-Z | Hi-Z |
| 1    | 0   | 0   | 0   | Hi-Z | Hi-Z | Hi-Z |
| 1    | 0   | 0   | 1   | Hi-Z | Hi-Z | PL   |
| 1    | 0   | 1   | 0   | Hi-Z | PL   | Hi-Z |
| 1    | 0   | 1   | 1   | Hi-Z | PL   | PL   |
| 1    | 1   | 0   | 0   | PĹ   | Hi-Z | Hi-Z |
| 1    | 1   | 0   | 1   | PL   | Hi-Z | PL   |
| 1    | 1   | 1   | 0   | PL   | PL   | Hi-Z |
| 1    | . 1 | 1   | 1   | PL   | PL   | PL   |

#### Note:

Hi-Z = Output buffers at high impedance (Output disabled).

Q = Output buffers at low impedance. Contents of output registers will be transferred to output pins.

PL = Output buffers at high impedance, or output disabled. Preload data supplied externally will be loaded into the output register at the rising edge of CLKP.

### **PIN DIAGRAM**

3

X6 [

X5 🗖 2

ХЗ

#### VL2010 DIP

64

63

62

61

¥7

X8

X9

X10

| T       | 0                                                   | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                           | 0   |                                                    |        | 0                                                           |         |
|---------|-----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|-----|----------------------------------------------------|--------|-------------------------------------------------------------|---------|
|         | TSL                                                 | XTF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                           | MSP | )                                                  |        | LS                                                          | Ρ       |
| .E      |                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                           |     |                                                    |        |                                                             | -       |
|         | Y15,P<br>P<br>P<br>P<br>P<br>P<br>P<br>P<br>P<br>P  | $ \begin{array}{c} 15 \\ 16 \\ 17 \\ 18 \\ 20 \\ 21 \\ 22 \\ 23 \\ 23 \\ 3 \\ 3 \\ 3 \\ 3 \\ 3 \\ 3 \\ 3 \\ 3 \\ 3 \\ $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 4<br>5<br>6<br>7<br>8<br>9<br>0<br>1<br>2 |     | 41<br>40<br>39<br>38<br>37<br>36<br>35<br>34<br>33 |        | P32<br>P31<br>P30<br>P29<br>P28<br>P27<br>P26<br>P25<br>P24 |         |
| ers     | Y11,P<br>Y12,P<br>Y13,P<br>Y14,P<br>V15,P           | 11 2<br>12 2<br>13 2<br>14 2<br>15 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0<br>1<br>2<br>3                          |     | 45<br>44<br>43<br>42                               | חחחח   | TSN<br>CLH<br>P34<br>P33<br>P32                             | 1<br>(P |
| and     | Y6,F<br>Y6,F<br>Y7,F<br>GN<br>Y8,F<br>Y9,F<br>Y10,P | 26   1<br>26   1<br>27   1<br>VD   1<br>28   1<br>29   1<br>29   1<br>10   1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 3<br>4<br>5<br>6<br>7<br>8<br>9           |     | 52<br>51<br>50<br>49<br>48<br>47<br>46             | תתתחחח | CLP<br>CLP<br>VCC<br>TC<br>TSX<br>PRE                       |         |
| as<br>N | Y0,F<br>Y1,F<br>Y2,F<br>Y3,F<br>Y4,F                | X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X10000<br>X100000<br>X100000<br>X100000<br>X100000<br>X100000<br>X100000<br>X100000<br>X100000<br>X100000<br>X100000<br>X100000<br>X100000<br>X1000000<br>X100000<br>X100000<br>X1000000<br>X1000000<br>X1000000<br>X10000000<br>X100000000 | 0                                         |     | 59<br>58<br>57<br>56<br>55<br>54<br>53             |        | X12<br>X12<br>X12<br>X14<br>X15<br>TSL<br>RNI<br>SUE        |         |



|        | Y   | BIT   | 15   | 14               | 13               | Ν            | 3      | 2                | 1                | 0                |
|--------|-----|-------|------|------------------|------------------|--------------|--------|------------------|------------------|------------------|
| INPUT  |     | VALUE | SGN  | 2-1              | 2-2              | à            | 2-12   | 2 <sup>-13</sup> | 2 <sup>-14</sup> | 2 <sup>-15</sup> |
|        | Y   | BIT   | 15   | 14               | 13               | 12           | 3      | 2                | 1                | 0                |
|        |     | VALUE | SGN  | 2-1              | 2-2              | 2-3          | $\sum$ | 2-13             | 2-14             | 2-15             |
|        | VTD | BIT   | 34   | 33               | 32               | $\square$    | E      |                  |                  |                  |
|        | XIP | VALUE | -24  | 2 <sup>3</sup>   | 2 <sup>2</sup>   |              | F      |                  |                  |                  |
| OUTPUT | MSP | BIT   | 31   | 30               | 29               | ζ            | 19     | 18               | 17               | 16               |
| COIPOI | mor | VALUE | 21   | 2 <sup>0</sup>   | 2-1              | $\mathbf{N}$ | 2-11   | 2-12             | 2 <sup>-13</sup> | 2-14             |
|        | LED | BIT   | 15   | 14               | 13               |              | 3      | 2                | 1                | 0                |
|        | LSP | VALUE | 2-15 | 2 <sup>-16</sup> | 2 <sup>-17</sup> | 2-18         | 27     | 2-28             | 2-29             | 2-30             |

### DATA FORMATS FRACTIONAL TWO'S COMPLEMENT

#### Notes:

1. The value of the input sign bits is  $-2^{0}$ .

2. The format shown uses a two's complement fractional notation. Note that the location of the binary point signifying the separation of the integer and fractional fields is just after the sign, between the sign (-2<sup>0</sup>) and and the next most significant bit for the multiplier inputs (-2<sup>1</sup>). This scheme is carried over to the output format, except that an extended significance to the integer field is provided to extend the utility of the accumulator. Consistent with the input notation, the output binary point is located between the -2<sup>0</sup> and the -2<sup>1</sup> bit positions.

The location of the binary point is arbitrary, as long as one is consistent with both input and output formats. One can consider the number field entirely integer, i.e., with the binary point just to the right of the least significant bit for input, product, and accumulated sum.

- 3. When nonaccumulating, all first four bits (P34 to P31) will indicate the sign of the product. The P30 term will also indicate the sign, except for the one exceptional case when monthinglying -1 X -1. Note that, with the additional significant bits available on this multiplier, -1 X -1 is a valid operation yielding +1 product.
- 4. Whether accumulating the sum of products or doing single products, there is no change in format. However, the three additional most significant bits (the guard bits) are provided to allow valid summation beyond that available for a single multiplication product. For further clarification, no difference exists between this organization and one which would have the product accumul;ation off-chip in a separate 18-bit adder. Taking the sign at the ost significant bit position guarantees that the largest number field will be used. In operation, the sign will be extended into the lesser significant bit positions when the accumulated sum only occupies a right-hand portrion of the accumulator. As an example, when the sum only occupies the least three bit positions, then the sign will be extended through the 16 most significant positions.

|        | InAdian Ob | -     |                 |                 |                 |                 |        |                 |                 |                 |
|--------|------------|-------|-----------------|-----------------|-----------------|-----------------|--------|-----------------|-----------------|-----------------|
|        | x          | BIT   | 15              | 14              | 13              | Ν               | 3      | 2               | 1               | 0               |
|        | ~          | VALUE | 2 <sup>15</sup> | 2 <sup>14</sup> | 2 <sup>13</sup> | Z               | 23     | 2 <sup>2</sup>  | 21              | 20              |
| INFUT  | Y          | BIT   | 15              | 14              | 13              | 12              | 3      | 2               | 1               | 0               |
|        |            | VALUE | 2 <sup>15</sup> | 2 <sup>14</sup> | 213             | 2 <sup>12</sup> | $\sum$ | 22              | 21              | 20              |
|        | VTD        | BIT   | 34              | 33              | 32              | $\square$       | E      |                 |                 |                 |
|        | XIP        | VALUE | 2 <sup>34</sup> | 233             | 232             |                 | P      | ~               |                 |                 |
| OUTPUT | MSD        | BIT   | 31              | 30              | 29              | 7               | 19     | 18              | 17              | 16              |
| COIFCI | MOP        | VALUE | 2 <sup>31</sup> | 2 <sup>30</sup> | 2 <sup>29</sup> | $\backslash$    | 219    | 2 <sup>18</sup> | 2 <sup>17</sup> | 2 <sup>16</sup> |
|        | ISP        | BIT   | 15              | 14              | 13              | 12              | 3      | 2               | 1               | 0               |
|        | LJP        | VALUE | 2 <sup>15</sup> | 2 <sup>14</sup> | 213             | 212             | P      | 2 <sup>2</sup>  | 21              | 20              |

### INTEGER MAGNITUDE



### **ABSOLUTE MAXIMUM RATINGS**

| Supply Voltage        | -0.5 to 7.0 V    |
|-----------------------|------------------|
| Input Voltage         | -0.5 to 7.0 V    |
| Output Voltage        | -0.5 to 7.0 V    |
| Operating Temperature | 0 °C to 70 °C    |
| Storage Temperature   | -65 °C to 150 °C |
| Lead Temperature (10  | Sec.) 300 °C     |
| Junction Temperature  | 175 °C           |

V Stresses above those listed under
 "Absolute Maximum Ratings" may
 v cause permanent damage to the
 device. These are stress ratings only.
 Functional operation of this device at
 these or any other conditions above

those listed on the operational sections of this specification is not implied and exposure to absolute maximum ratings conditions for extended periods may affect device reliability.

### DC CHARACTERISTICS TA = 0 °C to 70 °C, VCC = 5 V $\pm$ .25 V

| Symbol | Parameter                   | Min  | Тур | Max | Unit       | Conditions               |
|--------|-----------------------------|------|-----|-----|------------|--------------------------|
| VIH    | HIGH-level Input Voltage    | 2.0  |     |     | V          |                          |
| VIL    | LOW-Level Input Voltage     |      |     | 0.8 | V          |                          |
| VOH    | HIGH-level Output Voltage   |      | 2.4 | 3.0 | v          | VCC = Min; IOH =04<br>mA |
| VOL    | LOW-Level Output Voltage    |      | 0.3 | 0.4 |            | VCC = Min; IOL = 4.0 mA  |
| IIH    | HIGH-level Input Current    |      | 10  | 75  | μA         | VCC = Max; VIH = 2.4V    |
| IIL    | LOW-Level Input Current     |      | 10  | 75  | μA         | VCC = Max; VIL = 0.4v    |
| IOH    | HIGH-level Output Current   | -0.4 |     |     | mA         |                          |
| IOL    | LOW-Level Output Current    | 4.0  | 8.0 |     | mA         |                          |
| ICC    | Supply Current at DC        |      | 5   | 10  | mA         | VCC = Max; DC Cond.      |
| ICC/F  | Supply Current Increase/MHz |      | 4   | 8   | mA/<br>MHz | VCC = Max                |

### CAPACITANCE TA = 0 °C to 70 °C

| Symbol | Parameter          |                            | Min | Тур | Max | Unit       | Conditions |
|--------|--------------------|----------------------------|-----|-----|-----|------------|------------|
| ~      | Input Consoitance  | Clocks, Unlatched Controls |     |     | 20  | ~ <b>F</b> |            |
| CI     | input Capacitance  | Data, Latched Controls     |     |     | 10  | p-         |            |
| CO     | Output Capacitance |                            |     | 6   | 10  | pF         |            |



| Symbol | Parameter                   |           | Min | Тур | Max | Unit | Conditions        |
|--------|-----------------------------|-----------|-----|-----|-----|------|-------------------|
| tD     | Output Delay                | VL2010-90 |     | 25  | 35  |      |                   |
|        |                             | VL2010-65 |     | 20  | 30  | ns   | Load 1 (Figure 3) |
| tENA   | Output Enable Delay         |           |     | 30  | 35  |      | Load 2 (Figure 4) |
| tDIS   | Output Disable Dela         |           | 25  | 30  | ns  |      |                   |
|        | Multiply-Accumulate<br>Time | VL2010-90 |     | 65  | 90  | ns   |                   |
| tivia  |                             | VL2010-65 |     | 50  | 65  |      |                   |
| tPW    | Clock Pulse Width           |           | 25  |     |     | ns   |                   |
| tS     | Input Register Setup Time   |           | 25  |     |     | ns   |                   |
| tH     | Input Register Hold Time    |           | 0   |     |     | ns   |                   |

## AC CHARACTERISTICS TA = 0 °C to 70 °C, VCC = 5 V $\pm$ .25 V

### **TIMING DIAGRAM**





#### FIGURE 1. INPUT EQUIVALENT CIRCUIT



#### FIGURE 4. TEST LOAD FOR 3-STATE DELAY



FIGURE 2. OUTPUT CIRCUIT











FIGURE 3. TEST LOAD FOR DELAY MEASUREMENT







## **16 x 16 PARALLEL MULTIPLIER-ACCUMULATOR**

### FEATURES

- 16 X 16 parallel multiplication and product accumulation
- High speed Multiply-accumulate time: VL2044-65 50 ns typ 65 ns max VL2044-90 65 ns typ 90 ns max
- CMOS silicon-gate technology
- Low power; 0.2 W typical (VL2044-90)
- Single 5 V supply
- Standard TTL-compatible I/O levels
- Performs double-precision subtraction, addition, and multiplication, including rounding control
- With the exception of preload function, pin-for-pin functional replacement for WTL1010, WTL2010. TRW TDC1010J, LMA1010, and AMD 29510
- Available in 64-pin ceramic DIP, and soon to be available in plastic DIP. Plastic Leaded Chip Carrier, and Pin Grid Array
- Pin-for-pin replacement for WTL2044

### DESCRIPTION

The VL2044 is a 16 X 16 parallel multiplier-accumulator (MAC) fabricated using CMOS silicon-gate technology. The VL2044 offers ultralow power and very high performance. The high performance is achieved through the use of the efficient Booth's algorithm and advanced VLSI processing technology.

The VL2044 operates from a single five volt supply and is compatible with standard TTL logic levels. Except for the preload function, the VL2044 is a pin-for-pin functional replacement for the WTL1010, WTL 2010, TRW TDC1010J or AMD 29510.

The VL2044, under control of the ACC input (see Block Diagram), performs either the multiply only, or the multiplyaccumulate function. In either mode. input data X and Y can be specified as two's complement or unsigned magnitude. Input data representation is selectable via the input control line TC. In the multiply-only mode, extended product (XTP) data is signextended or set to zero for two's complement and unsigned-magnitude arithmetic, respectively. Additionally, a RND control is available for rounding up the most significant product (MSP) and extended product (XTP) data. In

the multiply-accumulate mode, the double-precision accumulated answer is rounded back to single-precision or single-precision plus XTP bits.

The VL2044 architecture includes input and output data registers, as well as 3-state output data buses with independent, non-registered control. Time-multiplexing is used for the common Least Significant Product (LSP) and Input Data (Y) I/O lines. Input lines TSX, TSM, and TSL, respectively, control the outputs of the XTP, MSP, and LSP registers.

In the multiply-accumulate mode (ACC active), output data can be added to or subtracted from the last product. When SUB is also active, subtraction is performed. Otherwise, addition is performed.

The VL2044 can be efficiently applied in a variety of digital signal processing functions, including digital filtering (recursive, non-recursive, wave) and FFT processing (complex multiplication, butterfly computation). In addition, the VL2044 can be employed effectively in upgrading the computational capability of mini- and microcomputer systems.

### ORDER INFORMATION

| Part<br>Number | Multiply/<br>Accumulate<br>Time | Package        |
|----------------|---------------------------------|----------------|
| VL2044-65CC    | 65 ns                           | Ceramic DIP    |
| VL2044-65PC    |                                 | Plastic DIP    |
| VL2044-65QC    |                                 | PLCC           |
| VL2044-65GC    |                                 | Pin Grid Array |
| VL2044-90CC    | 90 ns                           | Ceramic DIP    |
| VL2044-90PC    |                                 | Plastic Dip    |
| VL2044-90QC    |                                 | PLCC           |
| VL2044-90GC    |                                 | Pin Grid Array |







### SIGNAL DESCRIPTIONS

#### X Data Input

X is a 16-bit input. Data bits are loaded on the rising edge of CLKX.

#### Y/LSP

#### Data Input/

#### Data Output

These pins share functions between Y (16-bit data input) and LSP (least significant product output). Input data bits are loaded on the rising edge of CLKY. Output LSP data bits are available following the rising edge of CLKP.

#### MSP

#### Data Output

The 16-bit most-significant product output. MSP data is available following the rising edge of CLKP.

#### CLKX, CLKY

Input Clocks

These X and Y data input register clocks are active on their rising edges.

#### ACC

#### Accumulate

A HIGH level input permits the contents of the LSP, MSP, and XTP registers to be added to the multiplier output. A LOW level input allows multiplication only. The ACC signal is loaded on the rising edge of either CLKX or CLKY, and must be valid for the entire duration of input data.

#### SUB

#### Subtract

When ACC and SUB are both HIGH, the contents of the output register are subtracted from the last product generated, and the difference is stored back into the output registers at the rising edge of the next CLKP. When ACC is HIGH and SUB is LOW, addition instead of subtraction is performed. The SUB signal is loaded into the SUB register at the rising edge of either CLKX or CLKY.

The SUB signal must be valid over the same period that the input data is valid. When ACC is LOW, SUB is a "Don't Care" pin.

### RND

#### Round

A HIGH-level input causes a "1" to be added to the most significant bit of the LSP to round up MSP and XTP data. RND is loaded on the rising edge of either CLKX or CLKY and must be valid for the duration of the input data.

#### тс

# Two's Complement/ Unsigned Magnitude

A HIGH-level input defines X and Y as two's complement data, while a LOW level defines the input data as unsigned magnitude. As with ACC, SUB, and RND, TC is loaded at the rising edge of either CLKX or CLKY and must be valid for the duration of the input data.

#### TSX, TSM, TSL 3-state Output Controls

The LSP, MSP, or XTP output buffers are at high-impedance (output disabled) when TSL, TSM, or TSX, respectively, is HIGH. These are direct, nonregistered control signals. The output drivers are enabled when TSL, TSM, or TSX is LOW.

### CLKP

### Output Clock

The output registers are loaded following the rising edge of CLKP. This rising edge may occur after or before the falling edges of TSL, TSM, or TSX.

### **PIN CONFIGURATION**

VL2044 DIP

| X6<br>X5<br>X4<br>X3<br>X2<br>X1                                   | 1<br>2<br>3<br>4<br>5<br>6 | 64<br>63<br>62<br>61<br>60<br>59 | X7<br>X8<br>X9<br>X10<br>X11<br>X11<br>X12                         |
|--------------------------------------------------------------------|----------------------------|----------------------------------|--------------------------------------------------------------------|
| X0 U<br>Y0,P0 U<br>Y1,P1 U                                         | 7<br>8<br>9                | 58<br>57<br>56                   | $\begin{array}{c} 1 \\ 1 \\ 1 \\ 1 \\ 1 \\ 1 \\ 1 \\ 1 \\ 1 \\ 1 $ |
| Y2,P2 U<br>Y3,P3 U<br>Y4,P4 U                                      | 10<br>11<br>12             | 55<br>54<br>53                   |                                                                    |
| Y5,P5                                                              | 13<br>14<br>15             | 52<br>51<br>50                   |                                                                    |
|                                                                    | 16<br>17                   | 49<br>48                         |                                                                    |
| Y10,P10                                                            | 19<br>20                   | 47<br>46<br>45                   |                                                                    |
| Y12,P12                                                            | 21<br>22<br>23             | 44<br>43<br>42                   |                                                                    |
| Y15,P15                                                            | 24<br>25                   | 41<br>40                         | P32                                                                |
| P18<br>P19                                                         | 26<br>27<br>28             | 39<br>38<br>37                   | P30<br>P29<br>P28                                                  |
| P20<br>P21<br>P22<br>P23<br>P23<br>P23<br>P23<br>P23<br>P23<br>P23 | 29<br>30<br>31<br>32       | 36<br>35<br>34<br>33             | ☐ P27<br>☐ P26<br>☐ P25<br>☐ P24                                   |



|        |     | BIT   | 15   | 14               | 13             | N            | 3         | 2    | 1                | 0                |
|--------|-----|-------|------|------------------|----------------|--------------|-----------|------|------------------|------------------|
| INPUT  | X   | VALUE | SGN  | 2 <sup>-1</sup>  | 2-2            | A            | 2-12      | 2-13 | 2 <sup>-14</sup> | 2-15             |
|        | v   | BIT   | 15   | 14               | 13             | 12           | 3         | 2    | 1                | 0                |
|        | T   | VALUE | SGN  | 2-1              | 2-2            | 2-3          | 2         | 2-13 | 2-14             | 2-15             |
|        | ХТР | BIT   | 34   | 33               | 32             | 7            | E         |      |                  |                  |
| OUTPUT |     | VALUE | -24  | 2 <sup>3</sup>   | 2 <sup>2</sup> |              | $\square$ |      |                  |                  |
|        | MSP | BIT   | 31   | 30               | 29             | ζ            | 19        | 18   | 17               | 16               |
|        |     | VALUE | 21   | 2 <sup>0</sup>   | 2-1            | $\mathbf{N}$ | 2-11      | 2-12 | 2-13             | 2-14             |
|        | LSP | BIT   | 15   | 14               | 13             |              | 3         | 2    | 1                | 0                |
|        |     | VALUE | 2-15 | 2 <sup>-16</sup> | 2-17           | 2-18         | 27        | 2-28 | 2-29             | 2 <sup>-30</sup> |

### DATA FORMATS FRACTIONAL TWO'S COMPLEMENT

#### Notes:

1. The value of the input sign bits is -2<sup>0</sup>.

2. The format shown uses a two's complement fractional notation. Note that the location of the binary point signifying the separation of the integer and fractional fields is just after the sign, between the sign (-2<sup>0</sup>) and and the next most significant bit for the multiplier inputs (-2<sup>1</sup>). This scheme is carried over to the output format, except that an extended significance to the integer field is provided to extend the utility of the accumulator. Consistent with the input notation, the output binary point is located between the -2<sup>0</sup> and the -2<sup>1</sup> bit positions.

The location of the binary point is arbitrary, as long as one is consistent with both input and output formats. One can consider the number field entirely integer, i.e., with the binary point just to the right of the least significant bit for input, product, and accumulated sum.

- 3. When nonaccumulating, all first four bits (P34 to P31) will indicate the sign of the product. The P30 term will also indicate the sign, except for the one exceptional case when multiplying -1 X -1. Note that, with the additional significant bits available on this multiplier, -1 X -1 is a valid operation yielding +1 product.
- 4. Whether accumulating the sum of products or doing single products, there is no change in format. However, the three additional most significant bits (the guard bits) are provided to allow valid summation beyond that available for a single multiplication product. For further clarification, no difference exists between this organization and one which would have the product accumulation off-chip in a separate 18-bit adder. Taking the sign at the most significant bit position guarantees that the largest number field will be used. In operation, the sign will be extended into the lesser significant bit positions when the accumulated sum only occupies a right-hand portion of the accumulator. As an example, when the sum only occupies the least three bit positions, then the sign will be extended through the 16 most significant positions.

|        | v   | BIT   | 15              | 14              | 13              | Ν               | 3         | 2               | 1   | 0               |
|--------|-----|-------|-----------------|-----------------|-----------------|-----------------|-----------|-----------------|-----|-----------------|
| INPUT  | ~   | VALUE | 2 <sup>15</sup> | 2 <sup>14</sup> | 2 <sup>13</sup> | 2               | 23        | 2 <sup>2</sup>  | 21  | 2 <sup>0</sup>  |
|        | v   | BIT   | 15              | 14              | 13              | 12              | 3         | 2               | 1   | 0               |
|        | Y   | VALUE | 2 <sup>15</sup> | 2 <sup>14</sup> | 2 <sup>13</sup> | 2 <sup>12</sup> | $\sum$    | 2 <sup>2</sup>  | 21  | 20              |
|        | ХТР | BIT   | 34              | 33              | 32              | $\square$       | E         |                 |     |                 |
|        |     | VALUE | 2 <sup>34</sup> | 233             | 232             |                 | $\square$ |                 |     |                 |
|        | MSP | BIT   | 31              | 30              | 29              | ζ               | 19        | 18              | 17  | 16              |
| OUIFUI |     | VALUE | 2 <sup>31</sup> | 2 <sup>30</sup> | 229             | $\mathbf{N}$    | 219       | 2 <sup>18</sup> | 217 | 2 <sup>16</sup> |
|        | LSP | BIT   | 15              | 14              | 13              | 12              | 3         | 2               | 1   | 0               |
|        |     | VALUE | 215             | 2 <sup>14</sup> | 213             | 212             | P         | 22              | 21  | 20              |

### INTEGER MAGNITUDE



### **ABSOLUTE MAXIMUM RATINGS**

| Supply Voltage         | -0.5 to 7.0 V    |
|------------------------|------------------|
| Input Voltage          | -0.5 to 5.5 V    |
| Output Voltage         | -0.5 to 5.5 V    |
| Operating Temperature  | 0 °C to 70 °C    |
| Storage Temperature    | -65 °C to 150 °C |
| Lead Temperature (10 S | Sec.) 300 °C     |
| Junction Temperature   | 175 °C           |

Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only. Functional operation of this device at these or any other conditions above those listed on the operational sections of this specification is not implied and exposure to absolute maximum ratings conditions for extended periods may affect device reliability.

### DC CHARACTERISTICS TA = 0 °C to 70 °C, VCC = 5 V $\pm$ .25 V

| Symbol | Parameter                   | Min | Тур  | Max  | Unit       | Conditions              |
|--------|-----------------------------|-----|------|------|------------|-------------------------|
| VIH    | HIGH-level Input Voltage    | 2.0 | · ·  |      | V          | · · · · · ·             |
| VIL    | LOW-Level Input Voltage     |     | 1    | 0.8  | V          |                         |
| VOH    | HIGH-level Output Voltage   | 2.4 | 3.0  |      | V          | VCC = Min; IOH = -0.4A  |
| VOL    | LOW-Level Output Voltage    |     | 0.3  | 0.4  | V          | VCC = Min; IOL = 4.0 mA |
| IIH    | HIGH-level Input Current    |     | 10   | 75   | μA         | VCC Max; VIH = 2.4 V    |
| IIL    | LOW-Level Input Current     |     | 10   | 75   | μA         | VCC = Max; VIL = 0.4 V  |
| IOH    | HIGH-level Output Current   |     | -0.4 | -3.3 | mA         | VCC = Min; VOH = 2      |
| IOL    | LOW-Level Output Current    | 4.0 | 8.0  |      | mA         | VCC = Min; VOL = 0.4 V  |
| ICC    | Supply Current at DC        |     | 5    | 10   | mΑ         | VCC = Max; DC Cond      |
| ICC/F  | Supply Current Increase/MHz |     | 4    | 8    | mA/<br>MHz | VCC = Max               |

### **CAPACITANCE** TA = 0 °C to 70 °C (Note 1)

| Symbol | Parameter          |                            | Min | Тур | Max | Unit | Conditions |
|--------|--------------------|----------------------------|-----|-----|-----|------|------------|
| CI     | Input Capacitance  | Clocks, Unlatched Controls |     |     | 20  | - F  |            |
|        |                    | Data, Latched Controls     |     |     | 10  | рг   |            |
| со     | Output Capacitance |                            |     | 6   | 10  | рF   |            |

Note: 1. The specifications for capacitance (input and output) are guaranteed by design, but not tested.

| Symbol | Parameter                   |           | Min | Тур | Max | Unit  | Conditions        |
|--------|-----------------------------|-----------|-----|-----|-----|-------|-------------------|
| tD     | Output Delay                | VL2044-90 |     | 25  | 35  |       |                   |
|        |                             | VL2044-65 |     | 20  | 30  | ns    | Load 1 (Figure 3) |
| tENA   | Output Enable Delay         |           |     | 30  | 35  |       |                   |
| tDIS   | Output Disable Delay        |           |     | 25  | 30  | - ns  | Load 2 (Figure 4) |
| +NAA   | Multiply-Accumulate<br>Time | VL2044-90 |     | 65  | 90  |       |                   |
| una    |                             | VL2044-65 |     | 50  | 65  | - 115 |                   |
| tPW    | Clock Pulse Width           |           | 25  |     |     | ns    |                   |
| tS     | Input Register Setup Time   |           | 25  |     |     | ns    |                   |
| tH     | Input Register Hold         | 0         |     |     | ns  |       |                   |

### AC CHARACTERISTICS TA = 0 °C to 70 °C, VCC = 5 V $\pm$ .25 V

### **TIMING DIAGRAM**





### FIGURE 1. INPUT EQUIVALENT CIRCUIT



FIGURE 4. TEST LOAD FOR 3-STATE DELAY



**FIGURE 2. OUTPUT CIRCUIT** 



FIGURE 5. SUPPLY CURRENT VS OPERATING FREQUENCY











| SECTION 6<br>DATA<br>COMMUNICATIONS<br>PRODUCTS |
|-------------------------------------------------|
|                                                 |
|                                                 |
|                                                 |
|                                                 |
|                                                 |

Application Specific Logic Products Division


# VL16C450 • VL82C50A • VL82C50 ASYNCHRONOUS COMMUNICATIONS ELEMENT

# FEATURES

- Full double buffering
- Independent control of transmit, receive, line status and data set interrupts
- Modem control signals include CTS, RTS, DSR, DTR, RI and DCD.
- Programmable serial interface characteristics:

  - generation and detection
  - -1-, 1½- or 2-stop bit generation
  - -Baud rate generation (dc to 56K baud)
- · Full status reporting capabilities

# PIN DIAGRAMS

v

| L16C450<br>L82C50A<br>L82C50 |             |           |
|------------------------------|-------------|-----------|
| D0 1                         | $\neg \neg$ | 40 VCC    |
| D1 2                         |             | 39 RI     |
| D2 3                         |             | 38 DCD*   |
| D3 4                         |             | 37 DSR    |
| D4 5                         |             | 36 CTS    |
| D5 6                         | 1           | 35 MR     |
| D6 7                         |             | 34 OUT1   |
| D7 8                         |             | 33 DTR    |
| RCLK 9                       |             | 32 RTS    |
| SIN 10                       |             | 31 OUT2   |
| SOUT 11                      |             | 30 INTRPT |
| CSO 12                       |             | 29 NC     |
| CS1 13                       |             | 28 A0     |
| CS2 14                       |             | 27 A1     |
| BAUDOUT 15                   |             | 26 A2     |
| XTAL1 16                     |             | 25 ADS    |
| XTAL2 17                     |             | 24 CSOUT  |
| DOSTR 18                     |             | 23 DDIS   |
| DOSTR 19                     |             | 22 DISTR  |
| VSS 20                       |             | 21 DISTR  |
|                              |             |           |

\*ON THE VL82C50, PIN 38 (PIN 42 ON THE PLCC PACKAGE) IS ALSO CALLED RLSD  3-state TTL drive capabilities for bidirectional data bus and control bus

# DESCRIPTION

The VL16C450 is an asynchronous communications element (ACE) that is functionally equivalent to the VL82C50A, but is an improvedspecification version of that part. The improved specifications provide ensured compatibility with state-ofthe-art CPUs.

The VL16C450, VL82C50A, and VL82C50 ACEs serve as serial data input/output interfaces in microcomputer systems. They perform serial-to-parallel conversion on data characters received from peripheral devices or modems, and parallel-toserial conversion on data characters transmitted by the CPU. The complete status of the ACE can be read at any time during functional operation by the CPU. The information obtained includes the type and condition of the transfer operations being performed, and error conditions involving parity, overrun, framing or break interrupt.

A programmable baud rate generator is included that can divide the timing reference clock input by a divisor between 1 and (2<sup>16</sup>-1).



# **ORDER INFORMATION**

| Part<br>Number                            | Maximum<br>External<br>Clock<br>Frequency | Package                                                          |
|-------------------------------------------|-------------------------------------------|------------------------------------------------------------------|
| VL16C450-PC<br>VL16C450-CC<br>VL16C450-QC | 3.1 MHz                                   | Plastic DIP<br>Ceramic DIP<br>Plastic Leaded Chip Carrier (PLCC) |
| VL82C50A-PC<br>VL82C50A-CC<br>VL82C50A-QC | 3.1 MHz                                   | Plastic DIP<br>Ceramic DIP<br>Plastic Leaded Chip Carrier (PLCC) |
| VL82C50-PC<br>VL82C50-CC<br>VL82C50-QC    | 3.1 MHz                                   | Plastic DIP<br>Ceramic DIP<br>Plastic Leaded Chip Carrier (PLCC) |

#### Note:

Operating temperature range: 0°C to +70°C.

# **BLOCK DIAGRAM**



NOTE: APPLICABLE PIN NUMBERS ARE INCLUDED WITHIN PARENTHESES

# **ABSOLUTE MAXIMUM RATINGS**

| Ambient Temperatu<br>under Bias                     | re<br>0°C to +70°C |
|-----------------------------------------------------|--------------------|
| Storage<br>Temperature                              | - 65°C to + 150°C  |
| Voltage on any I/O<br>pin with Respect<br>to Ground | -0.5 V to $+7.0$ V |
| Power Dissipation                                   | 700 mW             |

Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only. Functional operation of this device at these or any other conditions above those indicated on the operational sections of this specification is not implied and exposure to absolute maximum rating conditions for extended periods may affect device reliability.

# **DC CHARACTERISTICS** TA = 0°C to +70°C, VCC = 5 V $\pm$ 5%, VSS = 0 V, unless otherwise specified

|                  |                                       | VL16C450 |      | VL82C50A |      | VL82C50 |      | 1     |                                                                                                                                                                                                                                                    |
|------------------|---------------------------------------|----------|------|----------|------|---------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol           | Parameter                             | Min      | Max  | Min      | Max  | Min     | Max  | Units | Conditions                                                                                                                                                                                                                                         |
| VILX             | Clock input LOW Voltage               | - 0.5    | 0.8  | - 0.5    | 0.8  | - 0.5   | 0.8  | v     |                                                                                                                                                                                                                                                    |
| VIHX             | Clock input HIGH Voltage              | 2.0      | VCC  | 2.0      | VCC  | 2.0     | VCC  | v     |                                                                                                                                                                                                                                                    |
| VIL              | Input LOW Voltage                     | - 0.5    | 0.8  | -0.5     | 0.8  | -0.5    | 0.8  | v     |                                                                                                                                                                                                                                                    |
| VIH              | Input HIGH Voltage                    | 2.0      | VCC  | 2.0      | VCC  | 2.0     | VCC  | v     |                                                                                                                                                                                                                                                    |
| VOL              | Output LOW Voltage                    |          | 0.4  |          | 0.4  |         | 0.4  | v     | IOL = 1.6 mA on all<br>Note 1                                                                                                                                                                                                                      |
| VOH              | Output HIGH Voltage                   | 2.4      |      | 2.4      |      | 2.4     |      | v     | IOH = -1.0  mA Note  1                                                                                                                                                                                                                             |
| ICC<br>(Average) | Average Power Supply Current<br>(VCC) |          | 20   |          | 20   |         | 20   | mA    | $\label{eq:VCC} \begin{array}{l} VCC = 5.25 \text{ V, No loads on} \\ \underline{SIN, DSR, RLSD, CTS,} \\ DCD. Ri = 2.0 \text{ V. All other} \\ inputs = 0.8 \text{ V. Baud rate} \\ generator at 4 \text{ MHz. Baud} \\ rate at 56K. \end{array}$ |
| IIL              | Input Leakage                         |          | ± 10 |          | ± 10 |         | ± 10 | μΑ    | VCC = 5.25 V, VSS = 0 V.<br>All other pins floating.                                                                                                                                                                                               |
| ICL              | Clock Leakage                         |          | ± 10 |          | ± 10 |         | ± 10 | μA    | VIN = 0 V, 5.25 V                                                                                                                                                                                                                                  |
| IOZ              | 3-state Leakage                       |          | ±20  |          | ±20  |         | ±20  | μΑ    | VCC = 5.25 V, VSS = 0 V.<br>VOUT = 0 V, 5.25 V<br>1) Chip deselected<br>2) Chip and write mode<br>selected                                                                                                                                         |
| VILMR            | MR Schmitt VIL                        |          | 0.8  |          | 0.8  |         | N/A  | V     |                                                                                                                                                                                                                                                    |
| VIHMR            | MR Schmitt VIH                        | 2.0      |      | 2.0      |      | N/A     |      | v     |                                                                                                                                                                                                                                                    |

#### CAPACITANCE TA = 25°C, f = 1.0 MHz, VCC = VSS = 0 V

| Symbol | Parameter                | Min | Тур | Max | Units | Conditions               |
|--------|--------------------------|-----|-----|-----|-------|--------------------------|
| CXTAL2 | Clock Input Capacitance  |     | 15  | 20  | pF    |                          |
| CXTAL1 | Clock Output Capacitance |     | 20  | 30  | pF    | fc = 1 MHz               |
| CI     | Input Capacitance        |     | 6   | 10  | pF    | Unmeasured pins returned |
| со     | Output Capacitance       |     | 10  | 20  | pF    | 10 V55                   |

# AC CHARACTERISTICS TA = $0^{\circ}$ C to + 70°C, VCC = 5 V ± 5%, Note 5

|        |                                           | VL16 | C450 | VL82 | VL82C50A |      | VL82C50 |     |       | Ī                                |
|--------|-------------------------------------------|------|------|------|----------|------|---------|-----|-------|----------------------------------|
| Symbol | Parameter                                 | Min  | Max  | Min  | Max      | Min  | Тур     | Max | Units | Conditions                       |
| tAW    | Address Strobe Width                      | 60   |      | 90   |          | 90   | 1       | 1   | ns    |                                  |
| tAS    | Address Setup Time                        | 60   |      | 90   |          | 110  |         | 1   | ns    |                                  |
| tAH    | Address Hold Time                         | 0    |      | 0    |          | 0    |         | -   | ns    |                                  |
| tCS    | Chip Select Setup Time                    | 60   |      | 90   |          | 110  |         |     | ns    |                                  |
| tCH    | Chip Select Hold Time                     | 0    |      | 0    |          | 0    |         |     | ns    |                                  |
| tCSS   | Chip Select Output Delay<br>From ADS      |      |      |      |          |      |         | 90  | ns    |                                  |
| tDID   | DISTR/DISTR Delay From ADS                |      |      |      |          | 0    |         |     | ns    |                                  |
| tDIW   | DISTR/DISTR Strobe Width                  | 125  |      | 175  |          | 175  |         |     | ns    |                                  |
| tRC    | Ready Cycle Delay                         | 175  |      | 500  |          | 1735 |         |     | ns    |                                  |
| RC     | Ready Cycle = tAR(1) + tDIW<br>+ tRC      | 360  |      | 755  |          | 2000 |         |     | ns    |                                  |
| tDD    | DISTR/DISTR to Driver<br>Disable Delay    |      | 60   |      | 75       |      |         | 150 | ns    | 100 pF load, Note 4              |
| tDDD   | Delay from DISTR/DISTR<br>to Data         |      | 125  |      | 175      |      |         | 250 | ns    | 100 pF load                      |
| tHZ    | DISTR/DISTR to Floating<br>Data Delay     | 0    | 100  | 100  |          | 100  |         |     | ns    | 100 pF load, Note 4              |
| tDOD   | DOSTR/DOSTR delay<br>from ADS             |      |      |      |          | 50   |         |     | ns    |                                  |
| tDOW   | DOSTR/DOSTR Strobe Width                  | 100  |      | 175  |          | 175  |         |     | ns    |                                  |
| tWC    | Write Cycle Delay                         | 200  |      | 500  |          | 1785 |         |     | ns    |                                  |
| wc     | Write Cycle = tAW* + tDOW<br>+ tWC        | 360  |      | 755  |          | 2100 |         |     | ns    |                                  |
| tDS    | Data Setup Time                           | 40   |      | 90   |          | 175  |         |     | ns    |                                  |
| tDH    | Data Hold Time                            | 40   |      | 60   |          | 60   |         |     | ns    |                                  |
| tCSC*  | Chip Select Output Delay<br>from Select   |      | 100  |      | 125      |      |         | 200 | ns    | 100 pF load                      |
| tRA*   | Address Hold Time from<br>DISTR/DISTR     | 20   |      | 20   |          | 50   |         |     | ns    | Note 2                           |
| tRCS*  | Chip Select Hold Time from<br>DISTR/DISTR | 20   |      | 20   |          | 50   |         |     | ns    | Note 2                           |
| tAR*   | DISTR/DISTR Delay<br>from Address         | 60   |      | 80   |          | 110  |         |     | ns    | Note 2                           |
| tCSR*  | DISTR/DISTR Delay from<br>Chip Select     | 5Ó   |      | 80   |          | 110  |         |     | ns    | Note 2                           |
| tWA*   | Address Hold Time from DOSTR/DOSTR        | 20   |      | 20   |          | 50   |         |     | ns    | Note 2                           |
| tWCS*  | Chip Select Hold Time from DOSTR/DOSTR    | 20   |      | 20   |          | 50   |         |     | ns    | Note 2                           |
| tAW*   | DOSTR/DOSTR Delay<br>from Address         | 60   |      | 80   |          | 160  |         |     | ns    | Note 2                           |
| tCSW*  | DOSTR/DOSTR Delay<br>from Select          | 50   |      | 80   |          | 160  |         |     | ns    | Note 2                           |
| tMRW   | Master Reset Pulse Width                  | 5    |      | 10   |          | 25   |         |     | μs    |                                  |
| tXH    | Duration of Clock HIGH Pulse              | 140  |      | 140  |          | 140  |         |     | ns    |                                  |
| tXL    | Duration of Clock LOW Pulse               | 140  |      | 140  |          | 140  |         |     | ns    | External Clock<br>(3.1 MHz Max.) |

#### AC CHARACTERISTICS (Cont.) TA = 0°C to + 70°C, VCC = 5 V ±5% VL16C450 VL82C50A VL82C50 Symbol Parameter Min Max Min Max Min Тур Max Units Conditions Transmitter Delay from rising edge of DOSTR/DOSTR (WR THR) tHR1 175 1000 N/A 100 pF load ns to Reset Interrupt Delay from falling edge of DOSTR/DOSTR (WR THR) 1000 tHR2 n/a n/a ns 100 pF load to reset interrupt **Delay from Initial INTR Reset** RCLK tIRS 8 24 8 24 16 Note 3 to Transmit Start Cycles Delay from initial Write RCLK tSI 16 32 16 32 24 Note 3 to Interrupt Cycles tSS Delay from Stop to Next Start 1000 ns Delay from Stop to Interrupt RCLK tSTI 8 8 8 8 8 Note 3 (THRE) Cycles Delay from DISTR/DISTR (RD tIR 250 1000 1000 ns 100 pF load IIR) to Reset Interrupt (THRE) Modem Control Delay from DOSTR/DOSTR tMDO 200 1000 1000 ns 100 pF load (WR MCR) to Output Delay to Set Interrupt from tSIM 1000 1000 100 pF load ns MODEM Input Delay to Reset Interrupt from tRIM 250 1000 1000 100 pF load ns DISTR/DISTR (RS MSR) **Baud Generator** N **Baud Divisor** 1 216-1 1 216-1 1 216-1 **Baud Output Negative** tBLD 125 250 250 100 pF load ns Edge Delay **Baud Output Positive** 125 250 250 100 pF load tBHD ns Edge Delay Baud Output Down Time tLW 425 425 425 ns fX = 2 MHz, $\div 2$ , 100 pF load tHW **Baud Output Up Time** 330 330 330 fX = 3 MHz, ÷ 3, 100 pF load ns Receiver Delay from RCLK to tSCD 2 2 2 μS Sample Time RCLK 2 tSINT Delay from Stop to Set Interrupt 1 1 1 Note 3 1 Cvcles Delay from DISTR/DISTR **t**RINT (RD RBR/RDLSR) to 1 1 1 100 pF load us Reset Interrupt

Notes:

- 1. Does not apply to XTAL2.
- 2. Applicable only when ADS is tied LOW.

3. RCLK = tXH and tXL.

4. Charge and discharge time is determined by VOL, VOH and the external loading.

5. All timings are referenced to valid 0 and valid 1 (see AC TEST POINTS).



# AC TESTING INPUT/OUTPUT WAVE FORM

#### EXTERNAL CLOCK INPUT (3.1 MHz MAXIMUM)

AC TEST POINTS



# TIMING DIAGRAM

# WRITE CYCLE



6--8

# TIMING DIAGRAMS



6-9

# TIMING DIAGRAMS

#### RECEIVER



TRANSMITTER



NOTES: 1. SEE WRITE CYCLE TIMING 2. SEE READ CYCLE TIMING

# TIMING DIAGRAM

#### MODEM CONTROLS



# **BASIC CONFIGURATION**

VL16C450, VL82C50A, VL82C50



## **TYPICAL COMPONENT VALUES**

| Crystal   | RP   | RX2   | C1       | C2       |
|-----------|------|-------|----------|----------|
| 3.072 MHz | 1 MΩ | 1.5 Ω | 10-30 pF | 40-90 pF |

# VL1935



# FEATURES

- HDLC, SDLC, ADCCP AND CCITT X.25 COMPATIBLE
- SDLC LOOP DATA LINK CAPABILITY
- FULL OR HALF DUPLEX OPERATION
- DC TO 2.0 MBITS/SEC DATA RATE
- PROGRAMMABLE/AUTOMATIC FCS (CRC) GENERA-TION AND CHECKING
- PROGRAMMABLE NRZI ENCODE/DECODE
- FULL SET OF MODEM CONTROL SIGNALS
- DIGITAL PHASE LOCKED LOOP
- FULLY COMPATIBLE WITH MOST CPU'S
- ERROR DETECTION: CRC, UNDERRUN, OVERRUN, ABORTED OR INVALID FRAME ERRORS
- STRAIGHT FORWARD CPU INTERRUPTS
- PROGRAMMABLE MODEM CONTROL INTERRUPTS
- DOUBLE BUFFERING OF DATA
- VARIABLE CHARACTER LENGTH (5, 6, 7 OR 8 BITS)
- RESIDUAL CHARACTER CAPABILITY
- ADDRESS COMPARE
- GLOBAL ADDRESS RECOGNITION
- EXTENDABLE ADDRESS FIELD
- EXTENDABLE CONTROL FIELD
- AUTOMATIC ZERO INSERTION AND DELETION
- MAINTENANCE MODE FOR SELF-TESTING
- PIN-COMPATIBLE REPLACEMENT FOR WD1933 AND WD1935

# **PIN DIAGRAM**



## DESCRIPTION

The VL1935 is a MOS/LSI microcomputer peripheral device which performs the functioning of interfacing a parallel digital system to a synchronous serial data communication channel employing ISO's HDLC, IBM's SDLC or ANSI's ADCCP line protocol. These protocols are referred to as Bit-Oriented Protocols (BOP).

The chip is fabricated in N-channel depletion load MOS technology and is TTL compatible on all inputs and outputs. This controller requires a minimum of CPU software by supporting a comprehensive frame-level instruction set and by hardware implementation of the low level tasks associated with frame assembly/disassembly and data integrity. It can be programmed to encode/decode NRZI data. The internal clock is then derived from the NRZI data using a digital phase locked loop.

The receiver and transmitter logic operates as two total independent sections with a minimum of common logic. The frames are automatically checked for errors during reception by verifying correct Frame Check Sequence (FCS). In transmit mode, the FCS is automatically generated by this controller and sent before the final Flag. It also continuously checks for other errors. In case of an error, the CPU is interrupted.

The controller recognizes and can generate Flag, Abort, Idle and GA characters. VL1935 can be used in an SDLC Loop configuration. An End of Block option is supplied to minimize CPU time. A full set of modem control signals are supplied to minimize external hardware.

# **ORDER INFORMATION**

| Part<br>Number                            | Clock<br>Frequency | Package                                                             |
|-------------------------------------------|--------------------|---------------------------------------------------------------------|
| VL1935-10PC<br>VL1935-10CC<br>VL1935-10QC | 0.5 MHz            | Plastic DIP<br>Ceramic DIP<br>Plastic Leaded<br>Chip Carrier (PLCC) |
| VL1935-11PC<br>VL1935-11CC<br>VL1935-11QC | 1.0 MHz            | Plastic DIP<br>Ceramic DIP<br>Plastic Leaded<br>Chip Carrier (PLCC) |
| VL1935-12PC<br>VL1935-12CC<br>VL1935-12QC | 1.5 MHz            | Plastic DIP<br>Ceramic DIP<br>Plastic Leaded<br>Chip Carrier (PLCC) |
| VL1935-13PC<br>VL1935-13CC<br>VL1935-13QC | 2.0 MHz            | Plastic DIP<br>Ceramic DIP<br>Plastic Leaded<br>Chip Carrier (PLCC) |

#### Note:

Operating temperature range: 0°C to +70°C.



# PIN DESCRIPTION

| PIN<br>NUMBER | MNEMONIC        | SIGNAL NAME                | FUNCTION                                                                                                                                                                                                                                                     |
|---------------|-----------------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1             | REOM            | Received End<br>of Message | Received End of Message with no Errors. This output signal is the inverse of IR7, bit 7 of the Interrupt Register.                                                                                                                                           |
| 2             | EOB             | End of Block               | This input, when low, function as an FCS command. Is independent of $\overline{\text{CS}}$ .                                                                                                                                                                 |
| 3             | RE              | Read Enable                | This input, when low (and $\overline{\text{CS}}$ is active), gates the content of addressed register onto the Data bus.                                                                                                                                      |
| 4             | <u>CS</u>       | Chip Select                | This input, when low, selects the VL1935 for a read or write operation to/from the Data bus.                                                                                                                                                                 |
| 5             | MISC OUT        | Misc Output                | This output is an extra programmable output signal for the conve-<br>nience of the user. Is controlled by the CR10 bit.                                                                                                                                      |
| 6             | INTRQ           | Interrupt<br>Request       | This output is high whenever any of the interrupt register bits IR7-IR3 are set. $\overline{TC}$ must be asserted to assert INTRQ.                                                                                                                           |
| 7             | WE              | Write Enable               | This input when low (and $\overline{\text{CS}}$ is active), gates the content of the Data bus into the addressed register.                                                                                                                                   |
| 8 thru 15     | D0-D7           | Data Bus                   | Bidirectional three-state Data Bus. Bit 7 is MSB.                                                                                                                                                                                                            |
| 16            | MR              | Master Reset               | This input, when low, initializes all the registers, and forces the VL1935 into an idle state. The VL1935 will remain idle until a command is issued by the CPU.                                                                                             |
| 17            | DTR             | Data Terminal<br>Ready     | Modem Control Signal. This output, when low, indicates to the Data<br>Communication Equipment (DCE) that the VL1935 is ready to trans-<br>mit or receive data.                                                                                               |
| 18            | DRQO            | Data Request<br>Output     | This output, when high, indicates that the Transmitter Holding Register<br>(THR) is empty and ready to receive a data character from the Data<br>bus for a transmit operation.                                                                               |
| 19            | DRQI            | Data Request<br>Input      | This output, when high, indicates that Receiver Holding Register (RHR) contains a newly received data character, available to be read onto the Data bus.                                                                                                     |
| 20            | V <sub>SS</sub> | V <sub>SS</sub>            | Ground                                                                                                                                                                                                                                                       |
| 21 thru 23    | A2, A0, A1      | ADDRESS                    | These inputs are used to address the CPU interface registers for read/<br>write operations.                                                                                                                                                                  |
| 24            | MISC IN         | Misc Input                 | This input is an extra input signal for the convenience of the user. The state is shown by the SR4 bit.                                                                                                                                                      |
| 25            | TD              | Transmitted Data           | This output transmits the serial data to the Data Communications<br>Equipment/Channel.                                                                                                                                                                       |
| 26            | RC              | Receive Clock              | This input is used to synchronize the received data.                                                                                                                                                                                                         |
| 27            | RD              | Received Data              | This input receives the serial data from the Data Communication<br>Equipment/Channel.                                                                                                                                                                        |
| 28            | NRZI            | NRZI                       | This input, when low, sets the VL1935 in NRZI mode.                                                                                                                                                                                                          |
| 29            | CTS             | Clear to Send              | Modem Control Signal. This input when low, indicates that the DCE is ready to accept data from the VL1935.                                                                                                                                                   |
| 30            | 1X/32X          | DPLL Select                | This input controls the internal clock. When high (1X clock), the ex-<br>ternal clock has the same frequency as the internal clock. When low<br>(32X clock), the external clock is 32 times faster than the internal clock<br>and the DPLL Logic is enabled. |
| 31            | TC              | Transmit Clock             | This input is used to synchronize the transmitted data, as well as gen-<br>erating either Receive or Transmit INTRQ's.                                                                                                                                       |



# PIN DESCRIPTION (continued)

| PIN<br>NUMBER | MNEMONIC        | SIGNAL NAME                         | FUNCTION                                                                                                                           |
|---------------|-----------------|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 32            | RTS             | Request to Send                     | Modem Control Signal. This output, when low, indicates to the DCE that the VL1935 is ready to transmit data.                       |
| 33            | DSR             | Data Set Ready                      | Modem Control Signal. This input, when low, indicates that the DCE is ready to receive or transmit data.                           |
| 34            | RI              | Ring Indicator                      | Modem Control Signal. This input, when low, indicates a ringing signal being received on the communication channel.                |
| 35<br>36      | RI1, RI0        | Ring Indicator<br>Interrupt Control | These inputs are used to program Ring Indicator interrupts.                                                                        |
| 37<br>38      | CD1, CD0        | Carrier Detect<br>Interrupt Control | These inputs are used to program Carrier Detect Interrupts.                                                                        |
| 39            | CD              | Carrier Detect                      | Modem Control Signal. This input, when low, indicates there is a car-<br>rier signal received by the local DCE from a distant DCE. |
| 40            | V <sub>CC</sub> | V <sub>CC</sub>                     | +5VDC                                                                                                                              |

TABLE 1. VL 1935 GLOSSARY

| DEFINITION/DESCRIPTION                                                                                                                                |
|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit-oriented protocols: SDLC, HDLC, and ADCCP                                                                                                         |
| 11111111 (seven or more contiguous 1's)                                                                                                               |
| Go-ahead pattern. 01111111 (0(LSB) followed by seven 1's)                                                                                             |
| First transmitted bit and first received bit. (Least significant bit)                                                                                 |
| Last transmitted bit and last received bit. (Most significant bit)                                                                                    |
| 11111111 11111111 (15 or more contiguous 1's)                                                                                                         |
| 01111110. Starts and ends a Frame.                                                                                                                    |
| Address-field in the Frame. Consists of one or more 8-bit characters. Defines the address<br>of a particular station.                                 |
| Control field in the Frame. Consists of one or two 8-bit characters.                                                                                  |
| Information field in the Frame. Consists of any number of bits.                                                                                       |
| Frame Check Sequence. A 16-bit error checking field sequence.                                                                                         |
| A communication element, consisting of a minimum of 32 bits, and delimited by FLAGS.                                                                  |
| An A-field character of eight 1's. When this is compared and matched in the Address com-<br>parator, the DRQI will be set, indicating a valid address |
| The last I-field character, consisting of a lesser amount of bits than the other I-field char-<br>acters in the Frame.                                |
| Data Communication Equipment (DCE). May be a modem.                                                                                                   |
| Length in time of a serial data bit.                                                                                                                  |
|                                                                                                                                                       |

# APPLICATIONS

| COMPUTER COMMUNICATIONS              | PACKET SWITCHING             |
|--------------------------------------|------------------------------|
| TERMINAL COMMUNICATIONS              | MULTIPLEXING SYSTEMS         |
| COMPUTER TO MODEM INTERFACING        | DATA CONCENTRATOR SYSTEMS    |
| LINE CONTROLLERS                     | SDLC LOOP DATA LINK SYSTEMS  |
| FRONT END COMMUNICATIONS             | DMA APPLICATIONS             |
| NETWORK PROCESSORS                   | COMMUNICATION TEST EQUIPMENT |
| TELECOMMUNICATION SWITCHING NETWORKS | LOCAL NETWORKS               |
| MESSAGE SWITCHING                    | MULTIDROP LINE SYSTEMS       |
|                                      |                              |



#### FIGURE 1. VL1935 BLOCK DIAGRAM



# A BRIEF DESCRIPTION OF HDLC, SDLC AND ADCCP PROTOCOLS

The VL1935 is compatible with HDLC, SDLC and ADCCP standard communication Link Protocols. These are bit-oriented, code independent, and ideal for full duplex communication. A single communication element is called a FRAME, which can be used for both link control and data transfer purposes.

The elements of a frame are the beginning eight bit FLAG (F) consisting of one logical "0" six 1's and a 0, an eight bit ADDRESS-FIELD(A), an eight bit CONTROL-FIELD (C), a variable (N bits) INFORMATION-FIELD, a sixteen bit FRAME-CHECK-SEQUENCE (FCS), and an eight bit end FLAG (F), having the same bit-pattern as the beginning flag.

In HDLC, the address (A) and control (C) characters are extendable (more than one character). An important characteristic of a frame is that its contents are made code transparent by use of a zero bit insertion and deletion technique. Thus, the user can adapt any format or code suitable for his system. The frame is bit-oriented, meaning that, bits not





characters in each field have specific meanings. The Frame Check Sequence (FCS) is an error detection scheme similar to the Cyclic Redundancy Checkword (CRC) widely used in magnetic disk storage devices. The frame format is shown in Figure 3.

#### FIGURE 3. VL1935 SDLC/HDLC/ADCCP FRAME FORMAT



Where:

FLAG = 01111110

Address field—One or more 8-bit characters defining the particular station

Control field-One or two 8-bit characters

Information field-Any number of bits (may be zero bits)

Frame Check Sequence-16-bit error checking field

The following features are also part of these protocols.

ZERO INSERTION/ZERO DELETION—Zero insertion/deletion is performed within the 2 Flags of a frame. If there are more than five 1's in a row, a 0 is automatically inserted after the fifth 1 and it is deleted upon reception by the receiver.

FRAME CHECK SEQUENCE (FCS)—A 16 bit cyclic redundancy check (CRC) calculation is performed during transmission of the data in between the 2 flags of the frame. The CRC is then transmitted after the 1-field and before the final FLAG. Upon reception the receiver also performs a CRC calculation on the incoming data. If there were no transmission error, the Receiver CRC equals F0B8 (hex).



#### HARDWARE ORGANIZATION

The VL1935 block diagram is illustrated in Figure 1 and described below.

#### **CPU Interface Registers**

All of these registers are addressable and to be read from and/or written into by the CPU via the Data bus. These are 8-bit registers and have to be enabled via Chip Select  $\overline{(CS)}$  before any data transfer can be done.

CONTROL REGISTER 1, 2, 3 (CR1, 2, 3) Operations are initiated by writing the appropriate commands into these registers. CR1 should be programmed last.

RECEIVER HOLDING REGISTER (RHR) When Data Request Input is set (DRQI=1), contains received assembled character.

ADDRESS REGISTER (AR) Contains the address of the accessed VL1935, which is to be compared to the received address character (A-field).

INTERRUPT REGISTER (IR) Contains the cause of the current interrupt request.

TRANSMITTER HOLDING REGISTER (THR) Is to be loaded with the next in line character to be transmitted, when Data Request Output is set (DRQO=1).

STATUS REGISTER (SR) Contains the overall status of the VL1935 plus some information of the last received frame.

#### Non-Addressable, Internal Registers

These registers are transparent to the user, but is mentioned in these data sheets to help the understanding of the VL1935.

TRANSMITTER REGISTER (TR) This 8-bit register functions as a buffer between the THR and the TD output. It is loaded from the THR (if Data Command) with the next character to be transmitted. A FLAG character may also be loaded into this register under program control. This character is automatically shifted out to the Transmit Data output. When the last bit of the current transmitted character has left the TR register, a new character will be loaded into this register, setting DRQO (Data command) or INTRQ (Abort, Flag or FSC command). If at the time when only one bit remains left in the TR register, and the THR is not loaded or a new command is not programmed (Data command), an underrun error will occur.

RECEIVER REGISTER (RR) The received data is, via the Zero-Deletion logic shifted into this 8-bit register. The data is here assembled to a 5, 6, 7 or 8-bit character length and then, under the right conditions, parallel transferred to the RHR register.

FCS RECEIVE REGISTER AND FCS XMIT REGISTER The VL1935 contains a 16-bit CRC check register (FCS REC. REG.) and a 16-bit CRC generation register (FCS XMIT REG.). The generating polynomial is:

$$G(X) = X^{16} + X^{12} + X^5 + 1$$

The transmitter and receiver initialize the remainder value to all ones before CRC accumulation starts. The data is multiplied by X<sup>16</sup> and is divided by G(X). Inserted 0's are not included in the accumulation. Under program control, the complement called the frame check sequence (FCS) is sent with high order bit first.

#### Various Internal Circuits

ADDRESS COMPARATOR This 8-bit comparator is used to compare the contents of the Address Register with the first address character of the incoming frame. This feature is enabled by a bit in the Command Register. If enabled and there is a match, the received frame is valid and DRQIs are generated for every character received (including the A-field). If enabled and there is not a match or there is no Global Address, the received frame is discarded. If not enabled, all received frames are valid and DRQIs are generated.

ZERO INSERTION The transmitted data stream is continuously monitored by this logic. A zero is automatically inserted following five contiguous 1 bits anywhere between the beginning FLAG and the ending FLAG of a frame. The insertion of the zero bit thus applies to the contents of the Address, Control, Information Data, and the FCS field.

ZERO DELETION The received data stream is continuously monitored by this logic. Upon receiving five contiguous 1 bits, the sixth bit is inspected. If the sixth bit is a 0, it is automatically deleted from the data stream. If the sixth bit is a 1, the seventh bit inspected; if it is a 0, a FLAG is recognized; if it is a 1 an ABORT or GO AHEAD is recognized. DATA BUS  $(\overline{D7}-\overline{D0})$  This is an inverted 8-bit bidirectional data bus.

SDLC LOOP-MODE CONTROL This logic supervises the VL1935 running in SDLC Loop mode. It monitors the received data for a GO-AHEAD pattern in the case when SDLC LOOP MODE bit (CR22) and ACT TRAN bit (CR16) are set. When GO-AHEAD pattern is received, this logic suspends the repeater function and initiates the transmitter function. For more details, see functional description of SDLC Loop Mode.

NRZI ENCODER/DECODER When this mode is selected, the NRZI Encoder encodes the "normal" transmitted data to NRZI formatted data and the NRZI Decoder decodes the received NRZI data to "normal" data.

A binary 1 for "normal data" is TD = high

A binary 1 for NRZI data is TD = no change.

A binary 0 for "normal data" is TD = low.

A binary 0 for NRZI data is TD = change of state.

COMPUTER INTERFACE CONTROL This logic interfaces the CPU, to the VL1935. It supervises the read and write functions to the addressable registers, generates data requests and interrupts, decodes and initiates commands, monitors the status of VL1935, etc.

MODEM INTERFACE CONTROL This logic interfaces and supervises the modem control signals to/from the VL1935. It provides both dedicated (EIA Standard) and user defined control functions.

CLOCK CONTROL This logic interfaces the transmit and receive clocks to the VL1935. It converts the external clocks to the necessary internal clocks.

#### FUNCTIONAL DESCRIPTION SDLC Loop Mode

The diagram below shows an SDLC Loop Data Link System. VL1935 can be used in any of these stations.



#### FIGURE 4. VL1935 SDLC LOOP DATA LINK



Each secondary station is normally a repeater in Receive mode (ACT REC bit on). The primary station is the loop controller. Signals sent out on the loop by the primary station are relayed from station to station, then back to the Primary. Any secondary station finding its address in the A-field captures the frame for action at that station. All received frames are relayed to the next station on the loop.

If a secondary station wants to transmit a message, it sets the ACT TRAN bit (CTS must be low) and waits for a GO AHEAD (GA) pattern. The ACT REC bit must be asserted for detection of the GA and other existing patterns. Until the GA pattern is received, this secondary station continues operating as a repeater. The primary station has the responsibility to generate the first GA pattern which can be accomplished by a flag followed by continuous 1's. The primary station must continue to send 1's until the GA has circulated through the entire loop. The first secondary station with its ACT TRAN bit set detects the GA and changes the last 1 bit of the GA pattern to a 0, thus generating the start flag of the frame it wants to transmit and preventing the GA pattern from propagating down the loop. The repeater function is then suspended by this secondary station and it goes into the transmit mode. When this secondary station completes its transmission frames, it resets the ACT TRAN bit and reverts back to the repeater mode. It repeats the 1's generated by the primary station to form another GA pattern from the final 0 of its ending flag. The GA pattern propagates through the loop until a secondary station down the loop, that wants to transmit (ACT TRAN bit is set), intercepts the GA pattern and starts to transmit as described, or until the primary station receives the idles (continuous 1's), indicating that the GA pattern has circulated through the entire loop. The primary station then generates another GA pattern or terminates its final data frame with continuous 1's.

Repeaters (Secondary stations) delay the received data by 4 bits (NRZ1 = 5 bits) before transmission.

The  $\overline{\text{RC}}$  and  $\overline{\text{TC}}$  clocks must be tied together. The internal DPLL will not function in the loop mode.

#### 1X/32X Clock Option

When 1X clock is selected, the data rate equals the external clock (receiver and transmitter).

When 32X clock is selected, the external clock rate is 32 times faster than the data rate.

#### Digital Phase Locked Loop (DPLL)

This feature is particularly useful in NRZI mode and/or when asynchronous modem is used. The purpose of the DPLL is to synchronize the internal 1X clock to the received data, thus insuring that this data is sampled in the middle of the incoming serial data bit. DPLL is automatically in operation when 32X clock is selected.

The DPLL Logic is initiated at the first received data transition in a frame. Corrections, if needed, are then made for each received data transition. A 32-counter is used for this operation. At the beginning of each frame and at the first received data transition, this 32 counter is reset. From this time on, the counter increments with one count for each external clock pulse. At count 16 the internal 1X clock is forced to change state to high (this transition = sampling time). At count 32, the counter resets itself. This forces the internal 1X clock again to change state back to low.



#### FIGURE 5. VL1935 DPLL TIMING DIAGRAM



At each received data transition, if the internal clock and the received data is out of synchronization, a correction is automatically made by  $\pm$  1 external clock period. See DPLL Timing Diagram in Figure 5.

#### End Of Block (EOB)

This is an FCS command. The main purpose of EOB is to allow the user to initiate FCS and FLAG without the need of using extra computer time. This is particularly practical in DMA applications. At the end of a frame, when the last information data character has already been loaded into the THR and once again DRQO is set, either a regular FCS command is written into CR1 Register, or EOB is to be activated. At the end of FCS, when INTRQ is set (XMIT OPCOM), the EOB if activated is to be reset again.

#### Serial Data Synchronization

The serial data is synchronized by the externally supplied Transmit Clock (TC) and Receive Clock (RC). When 1X clock is selected, the falling edge of  $\overline{TC}$  generates new transmitted data and the rising edge of RC is used to sample the received data. When 32X clock is selected, a 32-counter (in the DPLL Logic) is used to synchronize the internal clock. At time 0, when the counter is reset to 0, the new transmitted data is generated. At time 16 (counter = 16) the received data is sampled, insuring that sampling is done in the middle of the received serial data bit. At count 32, the counter is reset to 0 again.

#### Self Test (Diagnostic) Mode

This feature is a programmable Loop back of data, enabling the user to make a complete test of the VL1935 with a minimum of external circuitry. In this mode, transmitted data to the TD pin, is internally routed to the received data input circuitry, thus allowing a CPU to send a message to itself to verify proper operation of the VL1935. The modem control signals  $\overline{\text{DTR}}$  and  $\overline{\text{RTS}}$  are deactivated (off) to insure no interference to/from the Data Communication Equipment (DCE).  $\overline{\text{DSR}}$  and  $\overline{\text{CTS}}$  are internally activated for proper input conditions. TC and  $\overline{\text{RC}}$  should be supplied by the same source if 1X clock is selected.

#### Auto Flag

If this is selected and Data Command is executed, continuous Flags will be sent between frames. This eliminates the need to execute the Flag Command. In DMA applications in particular, this is very practical.

#### **Extended Addressing**

This type of addressing means, that there is more than one address character in the A-field. In receive mode, the first address character is compared in the Address Comparator of the VL1935. The other address character/s is to be compared by the CPU. The last address character is recognized by the fact that the LSB (bit  $2^{\circ}$ ) is a 1.

#### PROGRAMMING

#### **Controlling Operation**

Prior to initiating data transmission or reception, CON-TROL REGISTER 1-3 (CR1-3) must be loaded with control information from the CPU. The contents of these registers will configure the VL1935 for the user's specific data communication environment. These registers should be loaded during power-on initialization and after a reset operation. They can be changed at any time that the respective transmitter or receiver is deactivated. The CR1-3 dictate what the transmitter will send: the type of character (DATA, ABORT, FLAG or FCS), the number of bits per character, and the number of bits in the residual character. Similarly, they tell the receiver the types of frames to look for: the number of bits per I-field character, whether to perform an address compare, and whether to watch for an extended address. The Control Register also control Data Terminal Ready (DTR), Misc Out and the activation of both the transmitter and the receiver. For more detailed information, see Register Formats.

# Monitoring Operation

Monitoring is done by use of the Interrupt Register (IR) and Status Register (SR). The IR register indicates when a frame is completed (transmitted or received), if there was an error and if there is a Data Set Change. It also monitors the states of INTRQ, DRQO and DRQI.

The SR register indicates if an error is recognized by IR, what type of error. It also monitors the modern control signals; Ring Indicator (RI), Carrier Detect (CD), Data Set Ready (DSR) and Misc In.

Furthermore, the SR register monitors if the Receiver is idle, and also if in receive mode if the user has programmed the Receiver Character Length to be 8 bits per character, this register indicates the number of residual bits received. For more detailed information, see Register Formats.

#### Read/Write Control Of CPU Interface Registers

These registers are directly accessible from the CPU bus  $\overline{(D7-D0)}$  by a read and/or write operation by the CPU.

The CPU must set up the VL1935 register address  $\overline{A2}$ - $\overline{A0}$ ), Chip Select  $\overline{(CS)}$ , Write Enable  $\overline{(WE)}$  or Read Enable  $\overline{(RE)}$  before each data bus transfer operation.

During a write operation, the falling edge of  $\overline{WE}$  will initiate a VL1935 write cycle. The addressed register will then be loaded with the content of the Data Bus ( $\overline{D7}$ - $\overline{D0}$ ). During a read operation, the falling edge of  $\overline{RE}$  will initiate a VL1935 read cycle. The addressed register will then place its content onto the Data Bus ( $\overline{D7}$ - $\overline{D0}$ ). The read/write operation is completed, when  $\overline{CS}$  or  $\overline{RE}/WE$  is brought high.

See Read/Write Timing diagram for more detailed information.

For read and write operation, the CR1-3 registers normally need no external clock. After reset of CR1-3,  $\overline{TC}$  clock is required. The AR and THR registers need no external clock, and can only be written into. The RHR, IR and SR registers need Transmit Clock (TC) or Receive Clock (RC) to set various bits, and are read-only.

All these registers will get initialized by a Master Reset. A read operation of RHR resets the DRQI. A write operation to THR, resets the DRQO. A read operation of IR, resets IR bits 0 and 3-7. A read operation of SR, resets SR bits 0-2. For addressing and external clocks needed, see TABLE 2.

A more detailed description is shown in Figure 6 of each bit location. It should be known, that because the Data Bus Lines ( $\overline{D7}$ - $\overline{D0}$ ) have inverted logic, a logic 1, asserted means low state. Also, a modem control signal which is inverted (example  $\overline{DTR}$ ), is in on-state (asserted) when low:



# TABLE 2. DEVICE ADDRESS CODES

|    |    |    | CODEC |      |       | and the second |
|----|----|----|-------|------|-------|------------------------------------------------------------------------------------------------------------------|
| CS | A2 | A1 | Ā     | Read | Write | External Clock                                                                                                   |
| L  | н  | Н  | н     | CR1  | CR1   | None*                                                                                                            |
| L  | H  | н  | L     | CR2  | CR2   | None*                                                                                                            |
| L  | н  | L  | н     | CR3  | CR3   | None*                                                                                                            |
| L  | н  | L  | L     | RHR  | AR    | RHR=RC. AR=None                                                                                                  |
| L  | L  | н  | Н     | ĨR   | THR   | IR=TC. THR=None                                                                                                  |
| L  | L  | н  | L     | SR   |       | SR0-3=RC. SR4-7=None.                                                                                            |
| н  | х  | X  | х     | X    | X     |                                                                                                                  |

L = VIL at pins

H = VIH at pins

X = Don't care

#### REGISTER FORMATS

Below shows a short form register format.





#### Control Register 1 (CR1)

When initiating a transmit/receive operation, this should be the last register programmed.

**Miscellaneous Output (CR10)** This bit controls the Miscellaneous Output signal to the data set. When CR10 is a logical 0, Misc Out is off, when it is a logical 1, Misc Out is on.

\* 2.5 TC clock cycles are required after a Master Reset to be able to read and write.

**DTR Command (CR11)** This bit controls the data Terminal Ready ( $\overline{DTR}$ ) signal to the data set. When CR11 is a logical 0,  $\overline{DTR}$  is off. When CR11 is a logical 1,  $\overline{DTR}$  is on. When the Self-Test mode is selected,  $\overline{DTR}$  signal is forced to an off state.

**Transmitter Character Length (CR13, 12)** These bits control the transmitted I-field data character length. The data character may be 5, 6, 7 or 8 bits long.

TABLE 3. TRANSMITTER CHARACTER LENGTH

| CR13 (TCL1) | CR12 (TCL0) | Bits Per<br>Character |
|-------------|-------------|-----------------------|
| 0           | 0           | 8                     |
| 0           | 1           | 7                     |
| 1           | 0           | 6                     |
| 1           | 1           | 5                     |

**Transmitter Commands (CR15, 14)** These bits control the transmission of DATA (A-field, C-field and I-field), ABORT, FLAG, and FCS (FCS plus FLAG). When these commands are programmed, the previous command currently still in progress, will complete the transmission of its character. When this is done, a new character generated by this new command, will be transmitted.

CR 14, 15 can be programmed as follows:

- A. If DATA is programmed, the new character to be transmitted will be the character loaded (or still to be loaded) in the THR REGISTER.
- B. If ABORT is programmed, the new character will be eight logical 1's.
- C. If FLAG is programmed, the new character will be 01111110.
- D. If FCS is programmed, the new character which will be transmitted consists of the residual byte (which was automatically transferred to the XMIT REGISTER, provided that CR30-32 and are set correctly), followed by the 16-bit content of the FCS XMIT REGISTER and the FLAG.

One serial bit ahead of this new character (for FCS command the FLAG character), the CPU is signalled by DRQO or INTRQ that the VL1935 is again ready to receive a new command. DRQO is asserted by a DATA command and INTRQ (XMIT OPCOM) is asserted by an ABORT, FLAG or FCS command.



#### TABLE 4. TRANSMITTER COMMANDS

| CR15 (TC1) | CR14 (TC0) | Command | Character/s Transmitted | Signal to CPU |
|------------|------------|---------|-------------------------|---------------|
| 0          | 0          | DATA    | Content of THR          | DRQO          |
| 0          | 1          | ABORT   | 1111 1111               | INTRQ         |
| 1          | 0          | FLAG    | 0111 1110               | INTRQ         |
| 1          | 1          | FCS     | FCS + 01111110          | INTRQ         |

In the case of the DATA command the user has two choices; 1. Change the command. 2. Keep the DATA command and load a new character into the THB register For more information, please see the Transmission Timing diagram, Figure 7. See Table 4 for programming information.

Activate Transmitter (CR 16) This bit when set, enables the transmitter and sets  $\overline{\text{RTS}}$  signal. If in SDLC Loop Mode (CR22 = set), the transmitter waits for a Go-Ahead pattern before the transmitter is enabled.

Activate Receiver (CR 17) This bit when set activates the receiver, which begins shifting in frames one character at a time into RR register for inspection.

#### **CONTROL REGISTER 2 (CR2)**

Auto Flag (CR20) When set, Flags (without INTRQs) will be continuously transmitted in between frames, when otherwise the transmitter would be in idle state.

Self-Test Mode (CR21) When set, the Transmitter Data Output is internally connected to the Receiver Data input circuitry. The modem control output signals are deactivated (off state). The modem control input signals are internally activated. This mode allows off-line diagnostic.

**SDLC Loop Mode (CR22)** When set, the VL1935 is conditioned to operate in an SDLC Loop Data Link system (see SDLC Loop Mode).

**Receiver Character Length (CR24, 23)** These bits indicate to the receiver how many bits per character there are to assemble for the I-field. The I-field characters may be 5, 6, 7 or 8 bits long. The unused bits read from RHR will be logical 0.

#### TABLE 5. RECEIVER CHARACTER LENGTH

| CR24<br>(RCL1) | CR23<br>(RCL0) | Bits Per<br>Character |
|----------------|----------------|-----------------------|
| 0              | 0              | 8                     |
| 0              | 1              | 7                     |
| 1              | 0              | 6                     |
| 1              | 1              | 5                     |

#### TABLE 6. TRANSMITTER RESIDUAL COMMANDS

**Extended Address (CR25)** When set, this bit indicates to the receiver that there is more than one address character in the A-field. The receiver will expect another address character if the LSB in the current address character is a logical 0. The purpose of this bit: If a non-8-bit field character length is expected, the DRQIs will get out of synchronization if the VL1935 does not know exactly when the I-field will start. Not used in transmit mode.

Address Compare (CR26) When set, the first address character will be inspected in the Address Comparator. If there is a match with the AR register, or if the address compared is a Global Address (eight 1's) the frame is considered valid, causing DRQIs to be generated. Otherwise, the receiver does not react, and will continue comparing for a new valid address. If not set, all frames are considered valid.

Extended Control (CR27) When set, indicates that there are two control characters per name. If not set, there is only one control character per frame. The purpose of this bit: If a non-8-bit I-field character length is to be received, the DRQIs will get out of synchronization if the VL1935 does not know when the I-field will start. Not used in transmit mode.

#### **CONTROL REGISTER (CR3)**

Transmit Residual Character Length (CR32, 31, 30) (Table 6) These bits inform the transmitter what bit-length the residual character will be. If no residual character is to be sent, these bits must be set to logical 0. (See Transmitter Commands).

Unused (CR33-37) These bits are not used, and are always a logical 0.

#### **INTERRUPT REGISTER (IR)**

This register contains the information why an interrupt INTRQ was generated. An IR register read operation, will reset bits 0, and 3-7. The Transmitter clock must be active to generate an interrupt.

Loading the THR register, will reset DRQO (bit 1). Reading the RHR register, will reset DRQI (bit 2). A new interrupt will occur if one is pending.

| CR32<br>(TRES 2) | CR31<br>(TRES 1) | CR30<br>(TRES 0) | Residual Char. Length  |
|------------------|------------------|------------------|------------------------|
| 0                | 0                | 0                | No residual char. sent |
| 0                | 0                | 1                | 1 bit                  |
| 0                | 1                | 0                | 2 bits                 |
| 0                | <sup>'</sup> 1   | 1                | 3 bits                 |
| 1                | 0                | 0                | 4 bits                 |
| 1                | 0                | 1                | 5 bits                 |
| 1                | 1                | 0                | 6 bits                 |
| 1                | 1                | 1                | 7 bits                 |



| TABLE 7. DATA SET CHANGE PROGRAM |
|----------------------------------|
|----------------------------------|

| CD1                  | CD0                  | Interrupting edge of CD                         | RI1       | RIO  | Interrupting edge of RI                         |
|----------------------|----------------------|-------------------------------------------------|-----------|------|-------------------------------------------------|
| LO<br>LO<br>HI<br>HI | LO<br>HI<br>LO<br>HI | Rising and falling<br>Falling<br>Rising<br>None | L L I I I | Ŭ∓Ŭ∓ | Rising and falling<br>Falling<br>Rising<br>None |

If a new interrupt is generated while the CPU is reading the IR register, this new interrupt will set the respective bit in the IR register one bit time later (this to avoid losing any interrupt). The status of bits 3–7 will accumulate until the IR register is read by CPU.

**INTRQ (IR0)** When set, indicates an interrupt and that there are one or more bits set in positions 3 through 7 of this register. This bit is a mirror image of INTRQ signal (pin 6).

When pin 6 (INTRQ) is not used for pending interrupts information and only the IR register is read to obtain the status of the interrupt bits (polling method), a minimum of two (2) bits times must be allowed between IR registers "read's" to insure an orderly flow of pending interrupts.

**DRQO (IR1)** When set, indicates a Data request output. This bit is a mirror image of DRQO signal (pin 18).

**DRQI (IR2)** When set, indicates a Data Request input. This bit is a mirror image of DRQI signal (pin 19).

**Data Set Change (IR3)** When set, indicates a change of state of the Data Set (Data Communication Equipment). This is a change of state of DSR, CD or RI. The type of change of CD and RI that this bit will react to, is programmed by use of input signals CD1/CD0 and RI1/RI0 (Table 7).

XMIT Operation Complete with Underrun Error (IR4) When set, indicates that the transmitter command has been completed and there was an Underrun error. An Underrun error occurs when the Data Request Output (DRQO) is set, but THR register is not loaded in time.

XMIT Operation with No Error (IR5) When set, indicates that the transmitter command has been completed and there was no error.

**Received End of Message With Errors (IR6)** When set, indicates that a Received End of Message is detected, and there was an error. Errors include CRC, Overrun, Invalid Frame and Aborted Frame.

The SR Register bits 0-2 will indicate the exact type of error.

Received End of Message With No Error (IR7) When set, indicates that a Received End of Message is detected, and there was no error. The IR7 bit is the inverse of the REOM output signal.

#### STATUS REGISTER (SR)

This register contains the status of the receiver and some modem control signals. It also indicates (if REOM w/Errors) exactly what type of errors. If the Receiver Character Length is 8 bits, this register indicates the amount of Residual bits that was received. A read operation will reset bits 0-2.

Received Error/Received Residual Character Length (SR 2-0) If REOM w/NO ERROR (IR7) is set, these bits (SR 2-0), indicate the number of residual bits received (Table 8). If REOM WITH ERROR (IR 6) is set, these bits indicate the type of error that occurred (Table 9).

| TABLE | 8 |
|-------|---|
|-------|---|

|            |      | 6   | s  | 6 |
|------------|------|-----|----|---|
| CHAR       | RES  | B   | R  | R |
| LENGTH     | BITS | 0   | 1  | 2 |
| 8          | 0    | 0   | 0  | 0 |
| Bits/Char. | 1    | 0   | Ō  | 1 |
|            | 2    | Ō   | 1  | Ó |
|            | 3    | 0   | 1  | 1 |
|            | 4    | 1   | 0  | 0 |
|            | 5    | 1   | 0  | 1 |
|            | 6    | 1   | 1. | 0 |
|            | 7    | 1   | 1  | 1 |
| 7          | - 0  | 0   | 1  | 0 |
| Bits/Char. | 1    | 0   | 1  | 1 |
|            | 2    | . 1 | 0  | 0 |
|            | 3    | 1   | 0  | 1 |
|            | 4    | 1   | 1  | 0 |
|            | 5    | 1   | 1  | 1 |
|            | 6    | 0   | 0  | 1 |
| 6          | 0    | 1   | 0  | 0 |
| Bits/Char. | 1    | 1   | 0  | 1 |
|            | 2    | 1   | 1  | 0 |
|            | 3    | 0   | 0  | 1 |
|            | 4    | 0   | 1  | 0 |
|            | 5    | 0   | 1  | 1 |
| 5          | 0    | 0   | 0  | 1 |
| Bits/Char. | 1    | 0   | 1  | 0 |
|            | 2    | 0   | 1  | 1 |
|            | 3    | 1   | 0  | 0 |
|            | 4    | 1   | 0  | 1 |

| TABLE 9. |  |
|----------|--|
|----------|--|

| Bit Set           | Error                                         |
|-------------------|-----------------------------------------------|
| SR0<br>SR1<br>SR2 | CRC<br>Overrun<br>Aborted or<br>Invalid frame |

Receiver Idle (SR 3) When set, indicates that the receiver is currently IDLE.

Miscellaneous Input (SR4) This is a mirror image of MISC IN signal. When this signal is set, SR4 bit is set.

Data Set Ready (SR5) This is mirror image of DSR signal. When this signal is set, SR5 bit is set.

Carrier Detect (SR6) This is a mirror image of CD signal. When this signal is set, SR6 bit is set.



**Ring Indicator (SR7)** This is the inverse of the  $\overline{\text{RI}}$  signal. When SR7 bit is set, a ringing signal has been received on the communication channel.

#### TRANSMITTER OPERATION

Prior to this operation, the programmable inputs and the transmit mode related register bits need to be programmed according to the user's specific data communications environment. The last bit to be set is always the ACT TRAN (CR16) bit.

Before this, the INTRQ has to be cleared, which can be done by reading the IR register. For more detailed information how to program the VL1935 see Programming.

As an example of how to program the VL1935 let's assume a 24-bit information is to be transmitted. The I-field would then consist of three 8-bit characters with no residual bits. CR3 should then be 00 (Hex).

Bits CR23-CR27 are for reception only (see Receiver Operation). The last register to be programmed is CR1. If MISC OUT is not used, this may be ignored. If a modem is used, DTR (CR11) is to be set. CR13 and CR12 should be logical 0's (8-bit char. length). CR15 and CR14 should be logical 0's (Data Command). ACT TRAN (CR16) bit is to be set. The ACT REC (CR17) is for reception only.

The DTR bit, when set, activates the  $\overline{\text{DTR}}$  signal, indicating to the modem to prepare for communication. When the modem is ready, it sends back a Data Set Ready ( $\overline{\text{DSR}}$ ) to the VL1935. This causes the DSC (IR3) bit to set, which in turn activates INTRQ. The IR register is now read. Simultaneously, when the ACT TRAN (CR16) bit is set, this activates the Request to Send ( $\overline{\text{RTS}}$ ) signal, instructing the modem to enter into transmit mode. When the modem is ready to transmit data, it responds by activating the Clear to Send (CTS) signal.

The VL1935 is now conditioned to transmit. Now DRQO gets, set, indicating to the CPU (or DMA) to load the first character (Address) into the THR. When this is done, DRQO will reset. As soon as the VL1935 is ready to be loaded with the next character to be transmitted, DRQO is again set. When the THR register is again loaded with a character, DRQO will again reset.

This same sequence continues until the last I-field character to be transmitted is loaded into the THR. If CRC checking is to be used, the next time when DRQO is set, an FCS command has to be programmed. This is accomplished by either setting CR15, 14 to both logical 1's or by activating the EOB signal.

At the end of the FCS being transmitted, INTRQ will set indicating XMIT Operation Complete. The IR register is to be read to find out whether the frame was sent with or without error. Also the FCS Command which was used as described above has to be changed. If CR15, 14 were set, these have to be reset (to Data Command), or if EOB was activated, this signal has to be deactivated. At this same time, the ACT TRAN bit is allowed to be reset, causing the TD output to go idle after the end Flag is sent. If the ACT TRAN bit is kept set, continuous Flags will be sent following the FCS.

If a new frame is to be sent right after this first frame, only one Flag is needed in between frames, meaning the frames have one common Flag character. In this case, the second frame Address character may be loaded at the same time the FCS command is programmed during the first frame. Also, the ACT TRAN bit should be kept set in between frames. Every time DRQO gets set, the user must load the THR register before the last loaded character only has 1.5 bits left to be transmitted. In other words, when DRQO gets set, the user may wait (if 8-bit characters) up to 7.5 serial data bits before loading the THR. If THR is not loaded within this time, an Underrun error will occur.

If Auto Flag is not selected (CR20 = logical 0) the sequence will be a little different than described below. When the first DRQO is set, and after the Address character is loaded into THR. a Flag command is also programmed (CR15, 14 = 10).

This will set an interrupt (INTRQ), which indicates that the IR register must be read. Now, the Data Command is reprogrammed (CR15, 14 = 00).

For more information, see Transmission Timing diagram.

#### ABORT CONDITIONS

The function of prematurely terminating a data link is called an "Abort." The transmitting station aborts by sending eight consecutive 1's. Unintentional Abort caused by 1's in the A-C- or I-field is prevented by zero insertion. Intentional Abort may be sent by programming an Abort command. Abort will also be sent in the case where THR is not loaded in time or FCS command is not programmed in time (= underrun). This means that after the DRQO is set, to avoid Abort; THR must be loaded, EOB activated or FCS command programmed before there is only 1.5 bits left of the last character to be transmitted.

If this is not done, INTRQ (XMIT OPCOM w/underrun) is set and Aborts are transmitted until, either the command is changed or the THR is loaded. If in this same case, Auto Flag was programmed, one Abort (with INTRQ) would be generated, and thereafter continuous Flags (with no INTRQs) will be sent.

#### **RECEIVER OPERATION**

Prior to this operation, the programmable inputs and the receive mode related register bits have to be programmed according to the user's specific data communication environment. Also, the INTRQ has to be cleared. The last bit to be set is always the ACT REC (CR17) bit.

For more detailed information how to program the VL 1935 see Programming. As an example, let's assume a 26-bit information is to be received, and the I-field is made up by 8-bit characters. The CR3 register is only for transmit mode, and may be ignored here. CR20 and CR 12-16 bits are also for transmit mode only, and therefore may also be ignored. CR21 and CR22 are to be logical 0s (no Self-Test and no SDLC Loop Mode). CR24, 23 are to be logical 0's (8-bit character Ifield). If only one A-field and one C-field character is expected, and this VL1935 has a specific address, CR25 should be a logical 0, CR26 should be a 1, and CR27 should be a 0. The address to which the A-field should compare should be loaded into the AR register.

The status of the modem is monitored by the SR register, and it may be useful to read it at this time. CR1 is loaded as the last register. CR10 (Misc In) bit is optionable to the user. CR11 (DTR) is to be set if modem is used. CR17 (ACT REC) is now set, starting the input of frame characters into the Receiver Register (RR). When a Flag is detected, the next



8-bit character (address-character), when received, is compared to the character in the AR register. If these match, or if the received character is a Global address, this frame is valid, and the DRQI gets set. If the Address Comparator (CR26) bit is not set, all frames would be considered valid and generate DRQIs. When the RHR register is read, DRQI will be reset. All characters in a valid frame which are input into the RR register will set DRQI, and every time RHR is read by the CPU, DRQI will be reset.

During reception, the receiver also performs a CRC calculation on the incoming data. When the end Flag is received, INTRQ will get set, indicating Received End of Message. If the reception is completed with no error, IR7 (REOM w/no Error) bit will be set. When 8-bit characters are received SR 0-2 bits indicate the number of residual bits, in this case two. If IR6 (REOM w/Error) was set, SR 0-2 bits indicate the type of errors (see Receiver Error Indication).

When all characters including the A-field and the FCSfield are read, and when the REOM interrupt is recognized, it is up to the user to disassemble these mentioned characters from the received data. If non-8-bit characters are received, the amount of residual bits have to be calculated by the CPU after masking out the part of the ending Flag showing up in the last read character.

After end of frame, the receiver begins searching for a new frame.

(For more information, see Figure 8.)

#### RECEIVER ERROR INDICATION

When a frame is received, and REOM w/Error (IR6) is set, the type of error is indicated by the SR bits 0-2.

CRC Error (SR0) If the CRC calculation performed on the incoming data does not equal to F0B8 (HEX), this bit will be set.

**Overrun Error (SR1)** After DRQI is set, if the RHR is not read within one character minus one bit time, this bit will be set.

Aborted or Invalid Frame Error (SR2) If the frame is aborted or if in a frame the number of bits between flags are less than the required minimum (see Table 10), this bit will be set.

#### NOTES

- 1. TC-command—If two or more contiguous ABORTS or FLAGS are executed, the ACT TRAN (CR16) bit has to be reset before DATA-command can be executed.
- Master Reset (MR)—Needs no clock during activation of MR. However, 2.5 clock cycles are required to reset the VL1935 after the falling edge of MR.
- 3. IR-register—Immediately when IR register is read, bit 0 will reset. Bits 3-7 are reset one bit time later.
- SR-register—Bits 0-2 are reset one bit time after SR register is read.
- 5. SDLC Loop mode—Go-ahead pattern may be sent by either sending IDLE or ABORT after Flag.
- 6. TC and RC clocks are completely independent of each other.
- 7. It is recommended to verify that the INTRQ signal (pin 6) is set prior to reading the IR register.
- End Of Block (EOB) Minimum activated time must be one (1) character time. It can be activated indefinitely using IDDLE or AUTO FLAG (CR20).

#### TABLE 10.

|                                                   | Valid Frame For VL1935 |            |            |            |  |
|---------------------------------------------------|------------------------|------------|------------|------------|--|
| Receiver Programmed for                           | 8 bit char             | 7 bit char | 6 bit char | 5 bit char |  |
| 1 address, 1 control                              | ≥25 bits               | ≥23 bits   | ≥21 bits   | ≥19 bits   |  |
| 2 addresses, 1 control<br>1 address, 2 controls   | ≥25 bits               | ≥24 bits   | ≥23 bits   | ≥22 bits   |  |
| 3 addresses, 1 control<br>2 addresses, 2 controls | ≥25 bits               | ≥25 bits   | ≥25 bits   | ≥25 bits   |  |



DEACTIVATE ACT TRAN DEACTIVATE EOB

KMIT OPCOM.

NOTE 1. CR3 = 00H, CR2 = 01H, CR1 = 02H (FOR THIS EXAMPLE ONLY) NOTE 2. WRITE FCS COMMAND, OR ACTIVATE EOB. NOTE 3. INF. DATA MAY CONSIST OF ANY NUMBER OF BITS.

COMMANC NOTE 2)

MPTV £ L S L

THR EMPTY. LOAD INF. DATA CHARACTER

THR EMPTY. LOAD CONTRI CHARACTER

#### FIGURE 8. VL1935 RECEPTION TIMING DIAGRAM

тD

DROO

INTRO

IDLE

PROGRAMMERS (SEE NOTE ) SET ACT TRAN

g

THR EMPTY LOAD ADDRES CHARACTER



NOTE 1. AR = 19H, CR2 = 40H, CR1 = 02H (FOR THIS EXAMPLE ONLY)

NOTE 2. INF. DATA (I-FIELD) MAY CONSIST OF ANY AMOUNT OF BITS.

NOTE 3. CPU DOES NOT KNOW UNTIL RECEIVED END OF MESSAGE (REOM) THAT THIS IS AN FCS CHARACTER.



## SPECIFICATIONS

#### ELECTRICAL CHARACTERISTICS

### Absolute Maximum Ratings

| Storage Temperature       |  |
|---------------------------|--|
| Storage Temperature       |  |
| Voltage on any pin        |  |
| with respect to GND (VSS) |  |
| Power Dissipation         |  |

-55°C to +125°C (plastic package) -65°C to +150°C (ceramic package) -0.3 to +7.0 V

1W

#### DC Characteristics $T_A = 0^{\circ}C \text{ to } + 70^{\circ}$

# $V_{\mbox{\scriptsize SS}}$ = 0 V, $V_{\mbox{\scriptsize CC}}$ = +5 $\pm$ 0.25 V

# TABLE 11. VL1935 DC CHARACTERISTICS

| Symbol       | Parameter           | Min | Тур | Max | Units | Conditions          |
|--------------|---------------------|-----|-----|-----|-------|---------------------|
| ۱ <u>L</u> I | Input Leakage       |     |     | 10  | μA    | $VIN = V_{CC}$      |
| LO           | Output Leakage      |     |     | 10  | μA    | VOUT = VCC or VSS   |
| VIH          | Input High Voltage  | 2.4 |     |     | V     |                     |
| VIL          | Input Low Voltage   |     |     | 0.8 | V     | All Inputs          |
| VOH          | Output High Voltage | 2.4 | 1   |     | V     | $I_{O} = -100\mu A$ |
| VOL          | Output Low Voltage  |     |     | 0.4 | V     | IO = 1.6mA          |
| ICC          | Supply Current      |     | 70  | 210 | ma    |                     |

AC Characteristics

 $T_A = 0^\circ C$  to  $+70^\circ$ 

 $V_{SS} = 0$  V,  $V_{CC} = +5 \pm 0.25$  V

#### TABLE 12. VL1935 AC CHARACTERISTICS

|                                                                                                     |                                                                                                                                          | - 1                  | 0                        | -1                   | 1                        | - '                  | 12                       | -1                   | 3                        |                            |                      |
|-----------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|----------------------|--------------------------|----------------------|--------------------------|----------------------|--------------------------|----------------------|--------------------------|----------------------------|----------------------|
| <br>Symbol                                                                                          | Parameter                                                                                                                                | Min                  | Max                      | Min                  | Max                      | Min                  | Max                      | Min                  | Max                      | Units                      | Conditions           |
| TAS<br>TAH<br>TCSS<br>TCSH                                                                          | READ & WRITE (Fig. 9, 10)<br>Address Set-Up<br>Address Hold<br>Chip Select Set-up<br>Chip Select Hold                                    | 20<br>20<br>20<br>20 |                          | 20<br>20<br>20<br>20 |                          | 20<br>20<br>20<br>20 |                          | 20<br>20<br>20<br>20 |                          | ns<br>ns<br>ns<br>ns       |                      |
| T <sub>RED</sub><br>T <sub>DV</sub><br>T <sub>DRQIR</sub><br>T <sub>INTRQF</sub><br>T <sub>BF</sub> | READ (Fig. 9)<br>Data Delay from RE Asserted<br>Date Valid from RE Deasserted<br>DRQI Reset Delay<br>INTRQ Reset Delay<br>RE Pulse width | 0<br>325             | 315<br>140<br>280<br>280 | 0<br>300             | 290<br>140<br>280<br>280 | 0<br>275             | 265<br>140<br>280<br>280 | 0<br>250             | 240<br>140<br>280<br>280 | ns<br>ns<br>ns<br>ns<br>ns |                      |
| TDS<br>TDH<br>TDRQOR<br>TWE                                                                         | WRITE (Fig. 10)<br>Data Set-up<br>Data Hold<br>DRQO Reset Delay<br>WE Pulse width                                                        | 200<br>20<br>200     | 330                      | 180<br>20<br>180     | 330                      | 160<br>20<br>160     | 330                      | 140<br>20<br>140     | 330                      | ns<br>ns<br>ns             |                      |
| T <sub>RDS</sub><br>T <sub>RDH</sub><br>TTDO                                                        | TRANSMIT& RECEIVE (Fig.11)<br>Receive Data Set Up<br>Receive Data Hold<br>Transmit Data Out Delay                                        | 150<br>150           | 125                      | 150<br>150           | 125                      | 150<br>150           | 125                      | 150<br>150           | 125                      | ns<br>ns<br>ns             |                      |
| 1xF <sub>C</sub>                                                                                    | CLOCK<br>1X Clock                                                                                                                        |                      | .5                       |                      | 1.0                      |                      | 1.5                      |                      | 2.0                      | MHz                        | at 50% duty<br>cycle |
| <br>TR<br>TF                                                                                        | RISE & FALL (Fig. 12)<br>Rise Time<br>Fall Time                                                                                          |                      | 20<br>20                 |                      | 20<br>20                 |                      | 2.0<br>20<br>20          |                      | 2.5<br>20<br>20          | ns                         | cycle                |

NOTE: All A.C. Timing Measurements made at 0.8 V and 2.0 V.







NOTE 1. TRED and TDV starts from where both  $\overline{\text{CS}}$  and  $\overline{\text{RE}}$  are active.

# FIGURE 11. RECEIVER AND TRANSMITTER TIMING





FIGURE 10. VL1935 WRITE TIMING DIAGRAM

### FIGURE 12. VL1935 RISE AND FALL TIMING DIAGRAM





#### FIGURE 13. VL1935 TRANSMITTER FLOW CHART





FIGURE 14. VL1935 RECEIVER FLOW CHART



# VL2661



# ENHANCED PROGRAMMABLE COMMUNICATIONS INTERFACE

# **FEATURES**

# SYNCHRONOUS OPERATION

- 5- to 8-bit characters plus parity
- · Internal or external character synchronization
- · Odd, even or no parity

PIN DIAGRAM

D2 [ 1

D3 🗌 2

BxD [ 3

4

> D4 🗌 5

> D5 🗌 6

D6 🗆

D7 [

A1 10

CE 11

A0 [ 12

14

**R**∕₩ [] 13

TXC/SYNC 9

7

8

- · Local or remote maintenance loop back mode
- Baud rate: DC to 1 Mbps (1x clock)

# **ASYNCHRONOUS OPERATION**

#### 5- to 8-bit characters plus parity

• 1-, 1 1/2- or 2-stop bits transmitted

VL2661

28 🖾 D1

27 00

26 VCC

22 DSR

19 TXD

17 CTS

16 DCD

15 TXRDY

21 RESET

20 BRCLK

25 RXC/BKDET

- · Parity, overrun and framing error detection
- · Line break detection and generation
- Local or remote maintenance loop back mode
- · Baud rate: DC to 1 M bps (1x clock) -DC to 15.625 K bps (64x clock)

# **OTHER FEATURES**

- 16 internal rates for each set
- Double-buffered transmitter and receiver
- Dynamic character length switching

# DESCRIPTION

The VL2661 Enhanced Programmable Communications Interface (EPCI) is a programmable microprocessor peripheral which provides a bidirectional interface for data interchange. It contains interface logic for simultaneously transmitting and receiving standard synchronous communications, and provides the data formatting and control to interface serial asynchronous communication with bus-organized systems.





# ORDER INFORMATION

| Part<br>Number                            | Maximum<br>Baud Rate | Clock<br>Frequency | Package                                                             |
|-------------------------------------------|----------------------|--------------------|---------------------------------------------------------------------|
| VL2661-01PC<br>VL2661-01CC<br>VL2661-01QC | 19.2 K               |                    | Plastic DIP<br>Ceramic DIP<br>Plastic Leaded<br>Chip Carrier (PLCC) |
| VL2661-02PC<br>VL2661-02CC<br>VL2661-02QC | 38.4 K               | 4.9152 MHz         | Plastic DIP<br>Ceramic DIP<br>Plastic Leaded<br>Chip Carrier (PLCC) |
| VL2661-03PC<br>VL2661-03CC<br>VL2661-03QC | 19.2 K               | 5.0688 MHz         | Plastic DIP<br>Ceramic DIP<br>Plastic Leaded<br>Chip Carrier (PLCC) |

Note:

Operating temperature range: 0°C to +70°C.



# **PIN DESCRIPTIONS**

|                 | Pin               | · · ·                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------------|-------------------|-----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin             | Number            | Name                                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| CPU Inter       | face              |                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| RESET           | 21                | Reset                                   | Input signal that, when HIGH, performs a master reset of the VL2661. This<br>signal asynchronously terminates any device activity and clears the mode,<br>command and status registers. The VL2661 assumes the idle state and<br>remains there until initialized with appropriate control words.                                                                                                                                                                                                                                                                          |
| A0,A1           | 10,12             | Address<br>Lines                        | Address input lines used to select the internal registers.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| R/W             | 13                | Read/Write                              | Input signal that controls the direction of data transfers between the EPCI and the CPU. When CE and $\overline{R}/W$ are both LOW, the contents of the selected registers are transferred to the data bus. With $\overline{CE}$ LOW and $\overline{R}/W$ HIGH, a write to the select register is performed.                                                                                                                                                                                                                                                              |
| CE              | 11                | Chip<br>Enable                          | Input signal that, when LOW, Allows access to the selected register. When HIGH the D0-D7 lines are placed in the HIGH-impedance state.                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| D0-D7           | 27,28,<br>1,2,5-8 | Data Bus                                | Bidirectional 8-bit, 3-state, positive-true data bus used to transfer commands, data and status between the EPCI and the CPU.                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| TxRDY           | 15                | Transmitter                             | Output signal that is the complement of the Status Register (SR) bit SRO.<br>When LOW, this signal indicates that the transmit data holding register (TxHR)<br>is ready to accept a data character from the CPU. It goes HIGH when the<br>data character is loaded. This output is valid only when the transmitter is<br>enabled. It is an open-drain output that can be wire-ORed to the CPU<br>interrupt.                                                                                                                                                               |
| RxRDY           | 14                | Receiver<br>Ready                       | Output signal is the complement of Status Register (SR) bit. When LOW, this signal indicates that the receive data holding register (RxHR) has a character ready for input to the CPU. It goes HIGH when the RxHR is read by the CPU and also when the receiver is disabled. It is an open-drain output which can be wire-ORed to the CPU interrupt line.                                                                                                                                                                                                                 |
| TxEMT/<br>DSCHG | 18                | Transmitter<br>Empty/Data<br>Set Change | Output signal that is the complement of the Status Register (SR) bit. When LOW, this signal indicates that the transmitter has completed serialization of the last character loaded by the CPU, or that a change of state of the $\overline{\text{DSR}}$ or $\overline{\text{DCD}}$ inputs has occurred. This signal goes HIGH when the status register is read by the CPU if the TxEMT condition does not exist. Otherwise, the TxHR must be loaded by the CPU for this line to go to HIGH. It is an open-drain output that can be wire OR-ed to the CPU interrupt line. |
| Transmitte      | er/Receiver S     | ignals                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| BRLCK         | 20 | Baud Rate<br>Clock                        | Clock input to the internal baud rate generator. This is not required when external receiver and transmitter clocks are used.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------------|----|-------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RXC/<br>BKDET | 25 | Receiver<br>Clock/Break<br>Detect         | Bidirectional line that either controls character receive rate or provides a timing output. When the EPCI is programmed for external receiver clock, this pin acts as an input to control the rate at which characters are received. The frequency is programmed in Mode Register 1 and may be 1x, 16x or 64x the baud rate. Data is sampled on the rising edge. If internal receiver clock is programmed, this signal provides an output, either a 1x/16x clock or break detect signal, determined by programming Mode Register 2.                                                                   |
| TxC/<br>XSYNC | 9  | Transmitter<br>Clock/<br>External<br>Sync | Bidirectional line that controls the character transmit rate and provides a timing output. When the EPCI is programmed for external transmitter clock, this signal acts as an input and controls the rate at which the characters are transmitted. The frequency is programmed in Mode Register 1 and be may 1x, 16x or 64x the baud rate. Data changes on the falling edge of this clock. If the EPCI is programmed for internal transmitter clock, this signal can be either an output providing a 1x/16x clock or an input for external synchronization determined by Mode Register 2 programming. |



# PIN DESCRIPTIONS (Cont.)

|          | Pin            |                            |                                                                                                                                                                                                                                                                                                                                                             |
|----------|----------------|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin      | Number         | Name                       | Description                                                                                                                                                                                                                                                                                                                                                 |
| Transmit | ter/Receiver S | ignals (Cont.)             | ·                                                                                                                                                                                                                                                                                                                                                           |
| RxD      | 3              | Receive<br>Data            | Serial data input to the receiver.                                                                                                                                                                                                                                                                                                                          |
| TxD      | 19             | Transmit<br>Data           | Serial data output from the transmitter. When the transmitter is disabled, the output is in the HIGH, or "Mark", state.                                                                                                                                                                                                                                     |
| DSR      | 22             | Data Set<br>Ready          | Input signal that can be used to indicate Data Set Ready or Ring Indicator to the EPCI. Its complement appears in the Status Register as bit 7. A change of state on DSR causes $TxEMT/DSCHG$ to go LOW if either Command Register (CR) bit 0 or 2 is a one.                                                                                                |
| DCD      | 16             | Data<br>Carrier<br>Dectect | Input signal that must be LOW for the receiver to operate. If $\overline{DCD}$ goes HIGH while receiving, the RxC signal is internally inhibitied. The complement of $\overline{DCD}$ appears in the Status Register (SR) as bit 6. A change of state in $\overline{DCD}$ causes TxEMT/DSCHG to go LOW if either Command Register (CR) bit 0 or 2 is a one. |
| CTS      | 17             | Clear to<br>Send           | Input signal that must be LOW for transmitter to operate. If $\overline{\text{CTS}}$ goes HIGH while transmitting, the character currently in the transmit shift register is transmitted before termination. The TxD output will then go HIGH.                                                                                                              |
| DTR      | 24             | Data<br>Terminal<br>Ready  | Output signal that is the complement of Command Register (CR) bit 1. This<br>signal is normally used to indicate that the data terminal is ready to transmit or<br>receive data.                                                                                                                                                                            |
| RTS      | 23             | Request to<br>Send         | Output signal that is the complement of Command Register (CR) bit 5. If the transmit shift register is not empty when bit 5 is reset, $\overline{RTS}$ will not go HIGH until one $\overline{TxC}$ period after the last serial bit is transmitted.                                                                                                         |
| Power S  | upply          |                            |                                                                                                                                                                                                                                                                                                                                                             |
| VCC      | 26             | Supply                     | 5 V Supply                                                                                                                                                                                                                                                                                                                                                  |
| GND      | 4              | Ground                     | Supply and Signal Ground                                                                                                                                                                                                                                                                                                                                    |

# TABLE 1: BAUD RATE GENERATOR CHARACTERISTICSVL2661-01 (BRCLK = 4.9152 MHz)

| MR 2 |   |   | Actual Frequency |           |                 |               |         |
|------|---|---|------------------|-----------|-----------------|---------------|---------|
| 3    | 2 | 1 | 0                | Baud Rate | 16X Clock (KHz) | Percent Error | Divisor |
| 0    | 0 | 0 | 0                | 50        | 0.8             |               | 6144    |
| 0    | 0 | 0 | 1                | 75        | 1.2             |               | 4096    |
| 0    | 0 | 1 | 0                | 110       | 1.7598          | -0.01         | 2793    |
| 0    | 0 | 1 | 1                | 134.5     | 2.152           | _             | 2284    |
| 0    | 1 | 0 | 0                | 150       | 2.4             |               | 2048    |
| 0    | 1 | 0 | 1                | 200       | 3.2             | ·             | 1536    |
| 0    | 1 | 1 | 0                | 300       | 4.8             |               | 1024    |
| 0    | 1 | 1 | 1                | 600       | 9.6             | _             | 512     |
| 1    | 0 | 0 | 0                | 1050      | 16.8329         | 0.196         | 292     |
| 1    | 0 | 0 | 1                | 1200      | 19.2            | -             | 256     |
| 1    | 0 | 1 | 0                | 1800      | 28.7438         | -0.19         | 171     |
| 1    | 0 | 1 | 1                | 2000      | 31.9168         | -0.26         | 154     |
| 1    | 1 | 0 | 0                | 2400      | 38.4            | _             | 128     |
| 1    | 1 | 0 | 1                | 4800      | 76.8            | -             | 64      |
| 1    | 1 | 1 | 0                | 9600      | 153.6           | — .           | 32      |
| 1    | 1 | 1 | 1                | 19200     | 307.2           | —             | 16      |



#### **ABSOLUTE MAXIMUM RATINGS**

| Supply Voltag            | е    | – 0.3 V<br>+ 7.0 V |
|--------------------------|------|--------------------|
| Input/Output<br>Voltage  |      | − 0.3 V<br>+ 7.0 V |
| Operating<br>Temperature | Тор  | 0°C to 70°C        |
| Storage<br>Temperature   | TSTG | −55°C +150°C       |
|                          |      |                    |

Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only. Functional operation of this device at these or any other conditions above

those indicated in the operational sections of this specification is not implied and exposure to absolute maximum conditions for extended periods may affect device reliability.

#### DC CHARACTERISTICS TA = 0°C to 70°C, VCC = 5.0 V ± 5%, unless otherwise noted.

| Symbol | Characteristic                                 | Min | Тур | Max | Unit |
|--------|------------------------------------------------|-----|-----|-----|------|
| VIH    | Input HIGH Voltage                             | 2.0 |     | VCC | v    |
| VIL    | Input LOW Voltage                              |     |     | 0.8 | v    |
| IIN    | Input Leakage Current                          |     |     | 10  | μΑ   |
| ITSI   | Input Leakage Current for HIGH-Impedance State |     |     | 10  | μΑ   |
| VOH    | Output HIGH Voltage, ILOAD - 400 μA            | 2.4 |     |     | v    |
| VOL    | Output LOW Voltage, ILOAD 2.2 mA               |     |     | 0.4 | v    |
| CI     | Input Capacitance, fc = 1 MHz                  |     |     | 20  | pF   |
| CO     | Output Capacitance                             |     |     | 20  | pF   |
| PD     | Power Dissipation, VCC - 5.25 V                |     |     | 650 | mW   |

# RECEIVER/TRANSMITTER TIMING CHARACTERISTICS TA = 0°C to 70°C, VCC = 5.0 V ± 5%, unless otherwise noted.

| Symbol | Characteristic                                | Min | Тур    | Max            | Unit |
|--------|-----------------------------------------------|-----|--------|----------------|------|
| tB/TH  | TxC or RxC HIGH                               | 500 |        |                | ns   |
| tR/T1  | TxC or RxC LOW                                | 500 |        | 1.0            | ns   |
| fR/T   | TxC or RxC Frequency                          | DC  |        | 1.0            | MHz  |
| tBRH   | BRCLKHIGH                                     | 70  |        |                | ns   |
| tBRL   | BRCLKLOW                                      | 70  |        | e <sup>1</sup> | ns   |
| fBRG   | BRCLK Frequency, Note 1                       |     | 4.9152 |                | MHz  |
| tRxS   | RxD Setup                                     | 300 |        |                | ns   |
| tRxH   | RxD Hold                                      | 350 |        |                | ns   |
| tTxD   | TxD Delay from $\overline{TxC}$ , CL = 150 pF |     |        | 650            | ns   |
| tTCS   | Skew TxD vs $\overline{TxC}$ , CL = 150 pF    |     | 0      |                | ns   |

# READ/WRITE TIMING CHARACTERISTICS TA = 0°C to 70°C, VCC = 5.0 V ± 5%, unless otherwise noted.

| Symbol | Characteristic               | Min | Тур | Max | Unit |
|--------|------------------------------|-----|-----|-----|------|
| tCE    | CE Pulse Width               | 250 |     |     | ns   |
| tCED   | CE to CE Delay               | 600 |     |     | ns   |
| tSET   | Address and R/W Setup        | 10  |     |     |      |
| tHLD   | Address and R/W Hold         | 10  |     |     | ns   |
| tDS    | Write Data Setup             | 150 |     |     | ns   |
| tDH    | Write Data Hold              | 0   |     |     | ns   |
| tDD    | Read Data Delay, CL = 150 pF |     |     | 200 | ns   |
| tDF    | Read Data Hold, CL = 150 pF  | 10  |     | 100 | ns   |

#### Note: 1. fBRG = 4.9152 MHz for VL2661-1 and -2; fBRG = 5.0688 MHz for VL2661-3



# AC TEST CIRCUITS





TEST LOAD (ALL OTHER PINS)



# TIMING DIAGRAMS





#### **RECEIVE TIMING**



#### TRANSMIT TIMING



**CPU INTERFACE** 





# TABLE 1: BAUD RATE GENERATOR CHARACTERISTICS (Cont.)

# VL2661-02 (BRCLK = 4.9152 MHz)

|   | M  | ۲2 |   |           | Actual Frequency |               |         |
|---|----|----|---|-----------|------------------|---------------|---------|
| 3 | 2  | 1  | 0 | Baud Rate | 16X Clock (KHz)  | Percent Error | Divisor |
| 0 | 0  | 0  | 0 | 45.5      | 0.7279           | 0.005         | 6752    |
| 0 | 0  | 0  | 1 | 50        | 0.8              | -             | 6144    |
| 0 | 0  | 1  | 0 | 75        | 1.2              | -             | 4096    |
| 0 | 0  | 1  | 1 | 110       | 1.7598           | -0.01         | 2793    |
| 0 | 1  | 0  | 0 | 134.5     | 2.152            | -             | 2284    |
| 0 | 1  | 0  | 1 | 150       | 2.4              |               | 2048    |
| 0 | 1  | 1  | 0 | 300       | 4.8              |               | 1024    |
| 0 | 1  | 1  | 1 | 600       | 9.6              |               | 512     |
| 1 | 0. | 0  | 0 | 1200      | 19.2             |               | 256     |
| 1 | 0  | 0  | 1 | 1800      | 28.7438          | -0.19         | 171     |
| 1 | 0  | 1  | 0 | 2000      | 31.9168          | -0.26         | 154     |
| 1 | 0  | 1  | 1 | 2400      | 38.4             | _             | 128     |
| 1 | 1  | 0  | 0 | 4800      | 76.8             | -             | 64      |
| 1 | 1  | 0  | 1 | 9600      | 153.6            | _             | 32      |
| 1 | 1  | 1  | 0 | 19200     | 307.2            | -             | 16      |
| 1 | 1  | 1  | 1 | 38400     | 614.4            | _             | 8       |

## VL2661-03 (BRCLK = 5.0688 MHz)

| MR 2 |    |     |   |           | Actual Frequency |               |         |
|------|----|-----|---|-----------|------------------|---------------|---------|
| 3    | 2  | 1   | 0 | Baud Rate | 16X Clock (KHz)  | Percent Error | Divisor |
| 0    | 0. | 0   | 0 | 50        | 0.8              |               | 6336    |
| 0    | 0  | 0   | 1 | 75        | 1.2              | _             | 4224    |
| 0    | 0  | 1 . | 0 | 110       | 1.76             | _             | 2880    |
| . 0  | 0  | 1   | 1 | 134.5     | 2.1523           | 0.016         | 2355    |
| 0    | 1  | 0   | 0 | 150       | 2.4              | _             | 2112    |
| 0    | 1  | 0   | 1 | 300       | 4.8              | ·             | 1056    |
| 0    | 1  | 1   | 0 | 600       | 9.6              |               | 528     |
| 0    | 1  | 1   | 1 | 1200      | 19.2             |               | 264     |
| 1    | 0  | 0   | 0 | 1800      | 28.8             | - Minings     | 176     |
| 1    | 0  | 0   | 1 | 2000      | 32.081           | 0.253         | 158     |
| 1    | 0  | 1   | 0 | 2400      | 38.4             |               | 132     |
| 1    | 0  | 1   | 1 | 3600      | 57.6             |               | 88      |
| 1    | 1  | 0   | 0 | 4800      | 76.8             |               | 66      |
| 1    | 1  | 0   | 1 | 7200      | 115.2            | _             | 44      |
| 1    | 1  | 1   | 0 | 9600      | 153.6            |               | 33      |
| 1    | 1  | 1   | 1 | 19200     | 316.8            | 3.125         | 16      |

Note: 16X CLK is used in asynchronous mode. In synchronous mode, clock multiplier is 1X and BRG can be used only for TxC.

## FUNCTIONAL DESCRIPTION

The internal organization of the VL2661 EPCI consists of six major functional blocks (See Block Diagram): transmitter; receiver; clock control; modem control; and SYN/DLE control. These blocks communicate internally over common data and control buses. The data bus is also linked to the CPU via a bidirectional 3-state interface.

#### TRANSMITTER

The transmitter receives parallel data from the CPU and converts it to a serial bit stream, inserting start, stop and parity bits as selected by the user. It outputs a composite serial data stream.

#### RECEIVER

The receiver accepts serial data from the sending device and converts it to a parallel format, checking for appropriate start, stop and parity bits and control characters, as selected by the user. It sends the assembled character to the CPU.

# **TIMING CONTROL**

The timing control block contains a programmable baud rate generator (BRG). The BRG accepts external transmit (TxC) or receive (RxC) clocks to divide an external baud rate clock (BRCLK) for controlling data transfers. The BRCLK input allows the user to

program one of 16 commonly used baud rates.

#### **OPERATION CONTROL**

The operation control block contains four registers: Mode Registers 1 and 2 (MR1,MR2); the Command Register (CR); and the Status Register (SR). These registers are used to store configurations and operation commands from the CPU. They generate the necessary internal control signals for proper device operation, and maintain status information for the CPU.



#### MODEM CONTROL

The modem control section provides interfacing for three input signals and three output signals that are used for "handshaking" and status indication between the CPU and a modem.

## SYN/DLE CONTROL

This section contains control circuitry and three 8-bit registers storing the SYN2, and DLE character provided by the CPU. Each register is used in the synchronous operation mode to provide the characters required for synchronization, idle fill and data transparency.

#### OPERATION

The EPCI's operation is determined by programming the mode and command registers. Baud rate, asynchronous or synchronous communication, and SYN characters are established before enabling the transmitter or receiver.

#### ASYNCHRONOUS RECEIVER OPERATION

After the Mode Registers are configured, the receiver is enabled when the receiver enable (RxEN) bit of the command register (bit 2) is set to a one and DCD is LOW. With the receiver enabled, the EPCI then monitors the RxD input, waiting for a HIGH-to-LOW transition. When a transition is detected. the RxD input is again sampled onehalf-bit-time later. If RxD is HIGH at that time, a search for a valid start bit is started again. If, however, RxD is still LOW a valid start bit is assumed and the receiver continues to sample the RxD input at one-bit-time intervals until the correct number of data bits, the parity bit and one stop bit have been assembled. The character is then transferred to the receive data holding register (RxHR), the RxRDY bit of the Status Register (bit 1) is set, and the RxRDY output goes LOW. If the character length is less than 8 bits, the highorder unused bits in the holding register are set to zero. The parity error. framing error and overrun error status bits are strobed into the Status Register on the positive-going edge of RxC, corresponding to the received character boundary (Figures 1 and 2).

If the stop bit is present, the receiver immediately begins its search for the next start bit. If the stop bit is absent (framing error), the receiver interprets it as a space bit if it persists into the next bit time interval. If a break condition is detected (RxD is LOW for the entire character as well as the stop bit), only one character, consisting of all zeros (with the framing error status bit set), will be transferred to the holding register. The RxD input must go HIGH before a search for the next start bit begins (Figure 3).

Pin 25 can be programmed as a Break Detect (BKDET) output by setting bits 4 and 7 of Mode Register 2 (MR2). When these bits are set and a break is detected, the BKDET output will go HIGH. If RxD returns HIGH for at least one RxD time, BKDET returns LOW.

# SYNCHRONOUS RECEIVER OPERATION

When the EPCI is programmed for synchronous operation the receiver will remain idle until the receiver enable bit (bit 2) is set. At that time, the EPCI enters the hunt mode. Data is shifted into the receive data shift register (RxSR) one bit at a time. The contents of RxSR are then compared to the contents of the SYN1 register. If the two are not equal, the next bit is shifted in and the comparison is repeated. When the two registers match, the hunt mode is terminated and character assembly mode begins.

If the single-SYN operation is programmed, the SYN DETECT bit of the Status Register (bit 5) is set. If double-SYN operation is programmed, the first character assembled after SYN1 must be SYN2 in order for the SYN DETECT bit to be set. Otherwise, the EPC1 returns to the hunt mode. (Note that the sequence SYN1-SYN2 does not achieve synchronization).

When synchronization has been achieved, the EPCI continues to assemble characters and transfer them to the holding register, setting the Status Register RxRDY bit and asserting the RxRDY each time a character is transferred. The parity error (PE) and overrun error (OE) status register bits are set as appropriate. Further receipt of the appropriate SYN sequence sets the SYN DETECT Status Register bit. If the SYN stripping mode is set, SYN characters are not transferred to the holding register. (Note that the SYN characters used to establish initial synchronization are not transferred to the holding register in any case.)

By setting MR2 bit 4 and MR2 bit 7 to one, pin 9 (TxC/XSYNC) can be programmed as an external jam synchronization input. When XSYNC is selected, internal SYN1, SYN1-SYN2 and DLE-SYN1 detection is disabled. Each positive-going signal on XSYNC causes the receiver to establish svnchronization on the rising edge of the next RxC pulse. Character assembly starts with the RxD input at this edge. XSYNC must be prior to the next rising edge of RxC. This external synchronization causes the SYN DETECT Status Register bit to be set until the Status Register is read.

## ASYNCHRONOUS TRANSMITTER OPERATION

When the EPCI is programmed to transmit to the CPU, the transmitter remains idle until CTS is LOW and the transmitter enable (TxEN) bit of the Command Register (bit 0 is set. The EPCI responds by setting SR bit 0 and asserting the TxRDY output. When the CPU writes a character into the transmit data holding register (TxHR), SR bit 0 is reset and TxRDY returns HIGH. The character is then transferred to the transmit shift register (Tx SR) when it is idle or has completed transmission of the previous character. Status Register bit 0 is set again and TxRDY goes LOW (Figure 9).

In the asynchronous mode, the transmitter automatically sends a start bit followed by the programmed number of data bits, with the least significant bit being sent first. It then appends an optional odd or even parity bit and the programmed number of stop bits. If, following transmission of the data bits, a new character is not available in the transmit holding register, the TxD output remains in the mark (HIGH) condition and the TxEMT/DSCHG output and its corresponding status bit are asserted. Transmission resumes when the CPU loads a new character into the holding register. The transmitter can be forced to ouput a continuous LOW (Break) condition by setting CR bit 3.

1


**TIMING DIAGRAMS** 

FIGURE 1: RECEIVER OPERATION TIMING DIAGRAM



FIGURE 2: ASYNCHRONOUS RECEIVER OPERATION WITH LOSS OF DCD OR DISABLING RXEN





# SYNCHRONOUS TRANSMITTER OPERATION

When the EPCI is initially programmed for synchronous transmission, it remains in the idle state (RxD HIGH) until TxEN is set. At this point, TxD remains HIGH and TxRDY goes LOW. Both remain in this state until the first character (usually a SYN character) is written into the TxHR. This starts transmission, with TxRDY going LOW each time a character is shifted from the TxSR. If TxRDY is not serviced before the previous character is shifted out of the TxSR, the TxEMT output goes LOW and the EPCI automatically fills the pending gap with SYN1, SYN1, SYN2 doublets or DLE-SYN1 doublets, depending upon the state of MR1 bit 6 and MR1 bit 7. Transmission is continuous until TxEN is reset to zero.

If the send DLE bit (CR bit 3) is set, the DLE character is automatically transmitted prior to the transmission of any character stored in the TxHR. Since this is a one-time command, CR bit 3 does not have to be reset.

# VL2661 EPCI PROGRAMMING

Before data communications can begin, the EPCI must be programmed by writing to its Mode and Command Registers. Additionally, if synchronous communication has been selected, the appropriate SYN1, SYN2 and DLE registers must be loaded. Table 2 describes the register addressing requirements, and Figure 4 illustrates the initialization process.

In Table 2 MR1 and MR2 appear to have the same address. The EPCI has

an internal pointer that initially directs the first read or write to MR1. On the next access at that same address, the pointer directs the operation to MR2. A similar sequence occurs for the SYN and DLE registers; first SYN1, then SYN2, then DLE. If more than the required number of accesses is made, the internal pointer resets to the first register. The pointer is also reset to MR1 and SYN1 by a RESET input or a read of the Command Register. It is, however, unaffected by any other read or write operation.

# **REGISTER FORMATS**

The register formats are illustrated in Figures 5 through 8. The Mode Registers (MR1 and MR2) define general operating characteristics and the Command Register (CR) controls the basic operation defined by MR1 and MR2. The status register indicates the EPCI operating status and the condition of external inputs. These registers are cleared by a RESET input (SR bit 6 and SR bit 7 excepted).

# MODE REGISTER 1 (MR1)

Mode register/bits 0 and 1 select the communication mode and baud rate multiplier (Figure 5). In asynchronous mode the multiplier applies only if the external input option is selected by MR2 bit 4 and MR2 bit 5.

Bits 2 and 3 of MR1 select character length. When selected, character length does not include the parity bit, and does not include the start and stop bits in asynchronous operation. When set, MR1 bit 4 selects parity. A parity bit is transmitted with each character, and a parity check is performed on each character received.

Bit 5 of MR1 selects either odd or even parity. In asynchronous mode, MR1 bits 6 and 7 select the number of stop bits: 1, 1.5 or 2. If a 1x baud rate is programmed, 1.5 stop bits defaults to 1 on transmit. In the synchronous mode, bit 7 of MR1 controls the number of SYN characters used to establish synchronization, and the number of fill characters to be transmitted when TxRDY and TXEMT are zero. Bit 6 of MR1 controls selection of the transparent mode. When MR1 bit 6 is set (transparent selected), DLE-SYN1 is used for character fill and SYN detect (SR bit 5), but the normal synchronization sequence is used to establish character sync. When transmitting in the synchronous transparent mode, a DLE character in TxHR causes a second DLE character to be transmitted. If the send DLE command (CR bit 3) is active when a DLE character is in the TxHR, only one additional DLE is transmitted.

The bits in the Mode Register affecting character assembly and disassembly (MR1 bit 2-MR1 bit 6) can be changed dynamically (during active receive/ transmit operation). The character Mode Register affects both the transmitter and receiver; therefore, in synchronous mode, changes should be made only in half-duplex mode (RxEN OR TxEN HIGH (logical one), but not both simultaneously). In asynchronous

# FIGURE 3: FRAMING ERROR AND BREAK DETECTION TIMING





mode, character changes should be made when RxEN and TxEN are zero or when TxEN is one and the transmitter is marking in half-duplex mode (RxEN is zero).

To effect assembly/disassembly of the next received/transmitted character, MR1 bits 2 through 5 must be changed within n bit times of the active-going state of RxRDY/TxRDY. Transparent and non-transparent mode changes must occur within n-1 bit times of the character to be affected when the receiver or transmitter is active. (n is the smaller of the new and old character lengths).

# **MODE REGISTER 2 (MR2)**

Mode Register 2 bits 0 through 3 select the internal baud rate generator (BRG) (Figure 6). There are sixteen selectable rates for each version (Table 1).

Bits 4 through 7 of MR2 define the receive and transmit clock source and the function of pins 9 (TxC/SYNC) and 25 ( $\overline{RxC}/BKDET$ ).

# **COMMAND REGISTER (CR)**

Command register bit 0 enables or disables the transmitter (Figure 7). When TxEN is a zero, TxRDY and TxEMT are both HIGH, the transmitter is disabled. When TxEN goes active, TxRDY goes LOW, requesting the first character to be written to the TxHR, and the TxD output is enabled to transmit. When TxEN goes inactive, the EPCI completes transmission of any character still in the TxSR. TxD then goes to the marking state and TxRDY and TxEMT go HIGH. (Refer to Figure 9). Bit 1 of the CR controls the DTR output, which is a logical complement of CR bit 1.

Bit 2 of the command register enables or disables the receiver. When RxEN is a zero, the receiver is in an idle mode with  $\overline{RxRDY}$  HIGH. A zero-to-one transition of RxEN initiates a start bit search in asynchronous mode or initiate the hunt mode in synchronous transmission. A one-to-zero transition of RxEN immediately terminates receiver operation.

In the asynchronous mode, setting CR bit 3 forces the TxD output LOW (break condition) at the end of the current transmitted character. TxD remains LOW until CR bit 3 is cleared, at which time TxD goes HIGH for a minimum

# TABLE 2: VL2661 REGISTER ADDRESSING

| ĈĒ | A <sub>1</sub> | Ao | Ř∕W | Function                               |
|----|----------------|----|-----|----------------------------------------|
| 1  | X              | Х  | X   | Three-state Data Bus                   |
| 0  | 0              | 0  | 0   | Read Receive Holding Register (RxHR)   |
| 0  | 0              | 0  | 1   | Write Transmit Holding Register (TxHR) |
| 0  | 0              | 1  | 0   | Read Status Register (SR)              |
| 0  | 0              | 1  | 1   | Write SYN1/SYN2/DLE Registers          |
| 0  | 1              | 0  | 0   | Read Mode Registers (MR1, MR1/MR2)     |
| 0  | 1              | 0  | 1   | Write Mode Registers (MR1, MR1/MR2)    |
| 0  | 1              | 1  | 0   | Read Command Register                  |
| 0  | 1              | 1  | 1   | Write Command Register                 |

### FIGURE 4: INITIALIZATION FLOWCHART





1-bit time before resuming normal transmission.

In the synchronous mode setting, CR bit 3 forces the transmission of the DLE character prior to sending the character in the TxHR. Because this is a onetime command, bit 3 automatically resets.

Bit 5 of the CR controls the state of the RTS output. When CR bit 5 is a one, RTS goes LOW and the transmit logic enabled. A one-to-zero transistion of bit 5 causes RTS to go HIGH one TxC time after the last serial bit is transmitted, if the TxSR was not already empty.

Command Register bits 6 and 7 provide four alternative modes of operation in both synchronous and asynchronous operation. When both bits are zero, normal operation is selected. In the asynchronous mode, when only CR bit 6 is set, automatic echo mode is selected. In this mode, clocked, regenerated received data is automatically directed to the TxD line while normal receiver operation continues. The receiver must be enabled (bit 2 is a one), but the transmitter need not be enabled. CPU-to-receiver communications continue normally, but the CPUto-transmitter link is disabled. Only the first character of a break condition is echoed. The TxD output goes HIGH until the next valid start is detected.

The following conditions are true while in automatic echo mode:

- Data assembled by the receiver is automatically placed in the transmit holding register and retransmitted by the transmitter on the TxD output.
- 2. Transmit clock = receive clock.
- 3.  $\overline{TxRDY}$  output = 1.
- 4. The TxEMT/DSCHG pin reflects only the data set change condition.
- 5. The TxEN command (CR bit 0) is ignored.

In the synchronous mode, when only CR bit 6 is set, automatic SYN/DLE stripping is performed. The state of MR1 bits 6 and 7 controls which characters are stripped (Figure 1 and Table 3). Automatic stripping does not affect setting of the SYN and DLE detect status register bits.

#### FIGURE 5: MODE REGISTER 1



### FIGURE 6: MODE REGISTER 2

| 7 | 6   | 5 | 4 | 3   | 2 1 | 0     |         |            |
|---|-----|---|---|-----|-----|-------|---------|------------|
| L |     |   |   | L   | L   | SEE   | BAUD RA | TE TABLES  |
| 7 | 6   | 5 | 4 | TxC | RxC | PIN9  | PIN25   | MODE       |
| 0 | 0   | 0 | 0 | E   | Ε   | T×C   | RxC     | SYNC/ASYNC |
| 0 | l o | Ó | 1 | E   | 1   | TxC   | 1x      | SYNC/ASYNC |
| 0 | 0   | 1 | 0 | 1 1 | E   | 1x    | R×C     | SYNC/ASYNC |
| 0 | 0   | 1 | 1 | 1   | 1   | 1x    | 1x      | SYNC/ASYNC |
| 0 | 1   | 0 | 0 | E   | E   | TxC   | R×C     | SYNC/ASYNC |
| 0 | 1   | 0 | 1 | E   | 11  | TxC   | 16x     | SYNC/ASYNC |
| 0 | 1   | 1 | 0 | E.  | E   | 16x   | RxC     | SYNC/ASYNC |
| 0 | 1   | 1 | 1 | 1   | 1   | 16x   | 16x     | SYNC/ASYNC |
| 1 | 0   | 0 | 0 | 1   | E   | XSYNC | RxC     | SYNC       |
| 1 | 0   | 0 | 1 | E   | - E | TxC   | BKDET   | ASYNC      |
| 1 | 0   | 1 | 0 | 1   | E   | XSYNC | RxC     | SYNC       |
| 1 | 0   | 1 | 1 | 1   | 1   | 1x    | BKDET   | ASYNC      |
| 1 | 1   | 0 | 0 | 1   | E   | XSYNC | RxC     | SYNC       |
| 1 | j 1 | 0 | 1 | E   | 1   | TxC   | BKDET   | ASYNC      |
| 1 | 1   | 1 | 0 | I.  | E   | XSYNC | R×C     | SYNC       |
| 1 | 1   | 1 | 1 |     |     | 16x   | BKDET   | ASYNC      |

### FIGURE 7: COMMAND REGISTER





Two diagnostic modes are achievable in both synchronous and asynchronous operation: local loopback with CR bit 7 a one and CR bit 6 a zero, and remote loopback with both bits ones.

# LOCAL LOOPBACK, Note 1

- 1. The transmitter output is connected to the receiver input.
- 2. DTR is connected to DCE and RTS is connected to CTS.
- 3. Transmit clock is connected to the receive clock.
- 4. The DTR, RTS and TxD outputs are held HIGH.
- 5. The CTS, DCD, DSR and RxD inputs are ignored.

### **REMOTE LOOPBACK**

- Data assembled by the receiver is automatically placed in the transmit holding register and retransmitted by the transmitter on the TxD output.
- 2. Receive clock is connected to the transmit clock.
- 3. No data is sent to the local CPU, but the error status conditions (PE, OE, FE) are set.
- 4. The RxRDY, TxRDY, and TxEMT/ DSCHG outputs are held HIGH.
- 5. CR bit 1 (TxEN) is ignored.
- 6. All other signals operate normally.

### STATUS REGISTER (SR)

Status Register bit 0 is the transmitter ready (TxRDY) status bit. It is the logical complement of the TxRDY output (Figure 8). This bit indicates the state of the TxHR when the transmitter is enabled (TxEN is a one). A zero indicates that TxHR is full, a one indicates that TxHR is empty and requires servicing by the CPU. This bit is cleared by writing to TxHR or by disabling the transmitter (TxEN is a zero). Note that SR bit 0 is not set in either the auto echo or remote loopback modes.

Bit 1 of the SR is the receiver ready (RxRDY) status bit. It is the logical complement of the RxRDY output. This bit indicates the state of the RxHR when the receiver is enabled (RxÉN is a one). A zero indicates that the RxHR is empty, a one indicates that the RxHR is full and requires servicing by the CPU. This bit is cleared by writing

### **FIGURE 8: STATUS REGISTER**



to the TxHR or by disabling the receiver (RxEN is a zero).

Status Register bit 2 indicates a change of status of either DSR or DCD, or that the TxSR is empty. This bit is the logical complement of the TxEMT/ DSCHG output. A read of the status clears bit 2 if a state change on DSR or DCD has occurred. If a second successive read of the status register indicates bit 2 is a zero, DCD or DSR has changed. If bit 2 is still set, the TxSR is empty. Because the transmitter does not start until the first character has been written to the TxHR. TxEMT status is not reflected until transmission of the first character is complete, TxEMT status is cleared by writing to the TxHR or disabling the transmitter. Note that TxEMT status is set in synchronous mode even though "fill" characters are being transmitted.

### Notes:

1. CR bits 0, 1 and 5 must be set, CR bit 2 is a don't care.

When set, SR bit 3 reflects a parity error when parity checking is enabled in both the synchronous and asynchronous modes. In the synchronous transparent mode (MR2 bit 16 is a one) with the parity enable bit (MR2 bit 4) a zero, SR bit 3 indicates DLE detect when set. This indicates that a character matching the DLE register was received and the present character is neither SYN1 nor DLE. This bit is cleared when the next character following the above sequence is loaded into the RxHR, when the receiver is disabled or by a reset error command.

Bit 4 of the SR indicates an overrun error when set. An overrun condition exists when the CPU does not read the RxHR before the next received character is transferred to it. (The previous character is lost.) Bit 4 is cleared by the reset error command and when the receiver is disabled.



# TABLE 3: EFFECT OF MR17 AND MR16 ON CHARACTER FILL AND CHARACTER STRIPPING (SYNCHRONOUS MODE)

| MR17 | MR16 | Mode                      | Synchronizing<br>Sequence | Character Fill | Character(s)<br>Stripped CR7 = 0, CR6 = 1                                                                                                                                                                                                  |
|------|------|---------------------------|---------------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | 0    | Double SYN<br>Normal      | SYN1-SYN2                 | SYN1-SYN2      | SYN1<br>SYN1-SYN2 <sup>(1)</sup>                                                                                                                                                                                                           |
| 1    | 0    | Single SYN<br>Normal      | SYN1                      | SYN1           | SYN1 <sup>(1)</sup>                                                                                                                                                                                                                        |
| 0    | 1    | Double SYN<br>Transparent | SYN1-SYN2                 | DLE-SYN1       | DLE-SYN1 <sup>[1]</sup><br>SYN1-SYN2 <sup>[1]</sup> (Only Initial Synchronizing<br>Sequence)<br>DLE (also Sets SR3 if Parity Disabled and<br>it is not Following a DLE or SYN1)<br>In a DLE-DLE Sequence Only the First DLE<br>is Stripped |
| 1    | 1    | Single SYN<br>Transparent | SYN1                      | DLE-SYN1       | DLE-SYN1 <sup>[1]</sup><br>SYN1 (only Initial Synchronizing Sequence)<br>DLE and DLE-DLE same as Double SYN<br>Transparent                                                                                                                 |

# FIGURE 9: TRANSMITTER OPERATION TIMING DIAGRAM



### Notes:

1. Symbol indicates SYN DET status set upon detection of initial synchronizing characters and after SYNC has been achieved by detection of a DLE-SYN1 pair.



In the asynchronous mode, SR bit 5 indicates that the received character was not framed by a stop bit. If the RxHR is all zeros when bit 5 is set, a break condition was present. In synchronous non-transparent mode, bit 5 indicates receipt of the SYN1 character in single-SYN mode or the SYN1-SYN2 pair in double-SYN mode. In synchronous transparent mode, this bit is set upon detection of the initial synchronizing characters (SYN1 or SYN1-SYN2) and after synchronization has been achieved, when a DLE-SYN1 pair is received. The bit is reset when the receiver is disabled, when the reset. error command is given in asynchronous mode and when the Status Register is read by the CPU in the synchronous mode.

Status Register bits 6 and 7 reflect the condition of the DCD and DSR inputs, respectively. Their states are the logical complements of their respective inputs.

# VL6551.VL65C51



# ASYNCHRONOUS COMMUNICATION INTERFACE ADAPTER

baud)

# FEATURES

- On-chip baud rate generator: 15 programmable baud rates derived from a standard 1.8432 MHz external crystal (50 to 19,200 baud)
- Programmable interrupt and status register to simplify software design
- Single 5 V power supply
- · Serial echo mode
- · False start bit detection
- 8-bit bidirectional data bus for direct communication with the microprocessor
- Parity: odd, even, none, mark, space

# **PIN DIAGRAM**

- Data set and modem control signals provided
   Full-duplex or half-duplex operation
  - 5, 6, 7, 8, and 9 bit transmission
    - Low-cost HMOS technology (VL6551)

 External 16x clock input for nonstandard baud rates (up to 125K

· Programmable: word lengths,

generation and detection

number of stop bits, and parity bit

Low power consumption CMOS technology (VL65C51)

### DESCRIPTION The VI 6551/VL65C51 is an

Asynchronous Communications Interface Adapter (ACIA) which provides an interface between 6500/6800 microprocessor families and serial communication data sets and modems. A unique feature is the inclusion of an on-chip programmable baud rate generator, with a crystal being the only external component required. The device is available in both very low cost HMOS (VL65C51) and very low power CMOS (VL65C51) technologies.



# **ORDER INFORMATION**

| Part<br>Number                                             | Clock<br>Rate | Package                                                  |
|------------------------------------------------------------|---------------|----------------------------------------------------------|
| VL6551-01PC<br>VL6551-01CC<br>VL65C51-01PC<br>VL65C51-01CC | 1 MHz         | Plastic DIP<br>Ceramic DIP<br>Plastic DIP<br>Ceramic DIP |
| VL6551-02PC<br>VL6551-02CC<br>VL65C51-02PC<br>VL65C51-02CC | 2 MHz         | Plastic DIP<br>Ceramic DIP<br>Plastic DIP<br>Ceramic DIP |
| VL65C51-03PC<br>VL65C51-03CC                               | 3 MHz         | Plastic DIP<br>Ceramic DIP                               |
| VL65C51-04PC<br>VL65C51-04CC                               | 4 MHz         | Plastic DIP<br>Ceramic DIP                               |

Note: Operating temperature is 0°C to +70°C

VL6551 VL65C51

# VL6551•VL65C51

# SIGNAL DESCRIPTIONS

| Signal<br>Name | Pin<br>Number | Signal<br>Description                                                                                                                                                                                                                                                                                                                              |
|----------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RES            | 4             | During initialization, low on the Reset input causes internal registers to be cleared.                                                                                                                                                                                                                                                             |
| RxD            | 12            | The RxD input line receives serial NRZ data into the ACIA from the modem, last bit first.                                                                                                                                                                                                                                                          |
| Ø2             | 27            | The input clock is the system Ø2 clock and is used to trigger all data transfers between<br>the microprocessor and the VL65(C)51.                                                                                                                                                                                                                  |
| R₩             | 28            | The Read/Write signal is generated by the microprocessor and is used to control the direction of data transfers. A high on the $R/\overline{W}$ pin allows the processor to read the data supplied by the VL65(C)51. A low on the $R/\overline{W}$ pin allows a write to the VL65(C)51.                                                            |
| ÎRQ            | 26            | The interrupt request signal, from the interrupt control logic, is an open drain output, that<br>permits several devices to be connected to the common IRQ microprocessor input.<br>Normally a high level, IRQ goes low when an interrupt occurs.                                                                                                  |
| DB0 - DB7      | 18 - 25       | The DB0-DB7 pins are the eight data lines used for transfer of data between the processor<br>and the VL65(C)51. These lines are bidirectional and are normally high-impedance except<br>when selected during Read cycles.                                                                                                                          |
| CS0, CS1       | 2,3           | The two Chip Select inputs are normally connected to the processor address lines either directly or through decoders. The VL65(C)51 is selected when CS0 is high and CS1 is low.                                                                                                                                                                   |
| RS0, RS1       | 13, 14        | The two register select lines are normally connected to the processor address lines to<br>allow the processor to select the various VL65(C)51 internal registers. The following table<br>shows the internal register select coding.                                                                                                                |
|                |               | RS1 RS0 Write Read                                                                                                                                                                                                                                                                                                                                 |
|                |               | 0 0 Transmit Data Register Receiver Data Register                                                                                                                                                                                                                                                                                                  |
|                |               | 0 1 Programmed Reset (Data Status Register<br>is "Don't Care")                                                                                                                                                                                                                                                                                     |
|                |               | 1 0 Command Register                                                                                                                                                                                                                                                                                                                               |
|                |               | 1 1 Control Hegister                                                                                                                                                                                                                                                                                                                               |
|                |               | The table shows that only the Command and Control Registers are read/write. The<br>programmed reset operation does not cause any data transfer, but is used to clear the<br>VL65(C)51 registers. The programmed reset is slightly different from the hardware reset<br>and these differences are described in the individual register definitions. |
| XTAL1, XTAL2   | 6, 7          | External crystal (1.8432 MHz) connection that drives the various baud rates. An<br>externally generated clock may be used to drive the XTAL1 pin (XTAL2 pin must float).                                                                                                                                                                           |
| TxD            | 10            | The TxD output line is used to transfer serial NRZ data into the ACIA from the modern, LSB first. The receiver data rate is either the programmed baud rate or the rate of an externally generated receiver clock. This selection is made by programming the Control Register.                                                                     |
| RxC            | 5             | The RxC is a bidirectional pin that serves as either the receiver 16x clock input or the<br>receiver 16x clock output. Output results if the internal baud rate generator is selected.                                                                                                                                                             |
| RTS            | 8             | The $\overline{\text{RTS}}$ output is used to control the modem from the processor. The state of the $\overline{\text{RTS}}$ pin is determined by the contents of the Command Register.                                                                                                                                                            |
| CTS            | 9             | The $\overline{\text{CTS}}$ input is used to control the transmitter operation. The enable state is with $\overline{\text{CTS}}$ low. The transmitter is automatically disabled if $\overline{\text{CTS}}$ is high.                                                                                                                                |
| DTR            | 11            | This output pin is used to indicate the status of the VL65(C)51 to the modem. A low on DTR indicates the VL65(C)51 is enabled and a high indicates it is disabled. The processor controls this pin via bit 0 of the Command Register.                                                                                                              |
| DSR            | 17            | The DSR input is used to indicate to the VL65(C)51 the status of the modem. A low<br>indicates the "ready" state and a high, "not-ready". DSR is a high-impdeance input and<br>must not be a no-connect. If unused, it should be driven high or low, but not switched.                                                                             |
| DCD            | 16            | The DCD input is used to indicate to the VL65(C)51 the status of the carrier-detect output<br>of the mode. A low indicates that the modem carrier signal is present and a high, that it is<br>not. DCD, like DSR, is a high-impedance input and must not be a no-connect.                                                                          |

Note:

If Command Register Bit 0 = 1 and a change of state on  $\overline{DCD}$  occurs,  $\overline{IRQ}$  will be set, and Status Register Bit 5 will reflect the new level. The state of  $\overline{DCD}$  does not affect Transmitter operation, but must be low for the receiver to operate.

VL6551•VL65C51

# TRANSMITTER AND RECEIVER OPERATION CONTINUOUS DATA TRANSMIT

In the normal operating mode, the interrupt request output (IRQ) signals when the ACIA is ready to accept the next data word to be transmitted. This interrupt occurs at the beginning of the Start Bit. When the processor reads the Status Register of the ACIA, the interrupt is cleared. The processor must then identify that the Transmit Data Register is ready to be loaded and must then load it with the next data word. This must occur before the end of the Stop Bit, otherwise a continuous "Mark" will be transmitted.

# CONTINUOUS DATA RECEIVE

Similar to the continuous data transmit case, the normal operation of this mode is to assert  $\overline{IRQ}$  when the ACIA has received a full data word. This occurs at about the 9/16 point through the Stop Bit. The processor must read the Status Register and read the data word before the next interrupt, otherwise the overrun condition occurs.

# TRANSMIT DATA REGISTER NOT LOADED

If the processor is unable to load the Transmit Data Register in the allocated time, then the TxD line goes to the "Mark" condition until the data is loaded. IRQ interrupts continue to occur at the same rate as previously stated, except no data is transmitted. When the processor finally loads new data, a Start Bit immediately occurs, the data word transmission is started, and another interrupt is initiated, signaling for the next data word.

# EFFECT OF CTS ON TRANSIMITTER

The Clear-to-Send signal is generated by the modem. It is normally low (true state) but may go high in the event of some modem problems. When this occurs, the TxD line goes to the "Mark" condition after the entire last character (including parity and stop bit) has been transmitted. Bit 4 in the Status Register indicates that the Transmit Data Register is not empty and IRQ is not asserted. CTS is a transmit control line only, and has no effect on the ACIA receiver operation.

# EFFECT OF OVERRUN ON RECEIVER

If the processor does not read the Receive Data Register in the allocated time, when the following interrupt occurs, the new data word is not transferred to the Receive Data Register, but the Overrun Status Bit is set. Thus, the Receive Data Register will contain the last valid data word received and all following data is lost.

# ECHO MODE TIMING

In Echo Mode, the TxD line retransmits the data on the RxD line, delayed by one-half of the bit time.

# EFFECT OF CTS ON ECHO MODE In Echo Mode, the receiver operation is

unaffected by CTS; however, the transmitter is affected when CTS goes High, i.e., the TxD line immediately goes to a continuous "Mark" condition. In this case, however, the status request indicates that the Receive Data Register is full in response to an IRQ, so the processor has no way of knowing that the transmitter has ceased to echo.

OVERRUN IN ECHO MODE If overrun occurs in Echo Mode, the receiver is affected the same way as a normal overrun in Receive Mode. For the retransmitted data, when overrun occurs, the TxD line goes to the "Mark" condition until the first Start Bit after the Receive Data Register is read by the processor.

# FRAMING ERROR

Framing error is caused by the absence of Stop Bit(s) on received data. A framing error is indicated by the setting of bit 4 in the Status Register at the same time the Receive Data Register Full (RDRF) Bit is set, also in the Status Register. In response to IRQ, generated by RDRF, the Status Register can also be checked for the framing error. Subsequent data words are tested separately for framing error, so the status bit will always reflect the last data word received.

# EFFECT OF DCD ON RECEIVER

DCD is a modem output indicating the status of the carrier-frequencydetection circuit of the modem. This line goes high for a loss of carrier. Normally, when this occurs, the modem will stop transmitting data some time later. The ACIA asserts IRQ whenever DCD changes state and indicates this condition via bit 5 in the Status Register. Once such a change of state occurs, subsequent transitions will not cause interrupts or changes in the Status Register until the first interrupt is serviced. When the Status Register is read by the processor, the ACIA automatically checks the level of the DCD line, and if it has changed, another IRQ occurs.

# TIMING WITH 1-1/2 STOP BITS

It is possible to select 1-1/2 Stop Bits, but this occurs only for 5-bit data words with no parity bit. In this case, the  $\overline{IRQ}$ asserted for receive data register full occurs halfway through the trailing half-Stop Bit.

# TRANSMIT CONTINUOUS "BREAK"

This mode is selected via the ACIA Command Register and causes the transmitter to send continuous "Break" characters, beginning with the next character transmitted. At least one full "Break" character will be transmitted. even if the processor quickly reprograms the Command Register transmit mode. Later, when the Command Register is programmed back to normal transmit mode, an immediate Stop Bit will be generated and transmission will resume. If, while operating in the Transmit Continuous "Break" Mode, the CTS should go to a high, the TxD will be overridden by the CTS and will go to continuous "Mark" at the beginning of the next character transmitted after the CTS goes high.

# RECEIVE CONTINUOUS "BREAK"

In the event the modem transmits continuous "Break" characters, the ACIA will terminate receiving. Reception will resume only after a Stop Bit is encountered by the ACIA.

STATUS REGISTER OPERATION Because of the special functions of the various status bits, there is a suggested sequence for checking them. When an interrupt occurs, the ACIA should be interrogated, as follows:

- 1. Read Status Register. This operation automatically clears Bit 7 (IRQ). Subsequent transitions on DSR and DCD will cause another interrupt.
- Check IRQ (bit 7) in the data read from the Status Register. If not set, the interrupt source is not the ACIA.



- Check DCD and DSR. These must be compared to their previous levels, which must have been saved by the processor. If they are both 0 (modem "on-line") and they are unchanged, the remaining bits must be checked.
- 4. Check RDRF (Bit 3). Check for Receive Data Register full.
- 5. Check Parity, Overrun, and Framing Error (Bits 0-2) if the Receiver Data Register is full.
- 6. Check TDRE (Bit 4). Check for Transmitter Data Register empty.
- 7. If none of the above conditions exist, then CTS must have gone to the false (high) state.

# PROGRAM RESET OPERATION

A program reset occurs when the processor performs a write operation to the ACIA with RS0 low and RS1 high. The program reset operates somewhat differently from the hardware reset (RES pin) and is described as follows:

- Internal registers are not completely cleared. Check register formats for the effect of a program reset on internal registers.
- 2. DTR line goes high immediately.
- 3. Receiver and transmitter interrupts are disabled immediately. If IRQ is low when the reset occurs, it stays low until serviced, unless the interrupt was caused by DCD or DSR transition.

- 4. DCD and DSR interrupts are disabled immediately. If IRQ is Low and was caused by DCD or DSR, <u>then</u> it goes high; also DCD and DSR status bits subsequently will follow the input lines, although no interrupt will occur.
- 5. Overrun cleared, if set.

#### MISCELLANEOUS

- 1. If Echo Mode is selected, RTS goes Low.
- 2. If Bit 0 of Command Register is 0 (disabled), then:
  - a) All interrupts are disabled, including those caused by DCD and DSR transitions.
  - b) Transmitter is disabled immediately.
  - c) Receiver is disabled, but a character currently being received will be completed first.
- Odd parity occurs when the sum of all the 1 bits in the data work (including the parity bit) is odd.
- In the receiver mode, the received parity bit does not go into the Receiver Data Register, but generates parity error or no parity error for the Status Register.
- 5. Transmitter and Receiver may be in full operation simultaneously. This is full-duplex mode.
- If the RxD line inadvertently goes low and then high right after a Stop Bit, the ACIA does not interpret this as a Start Bit, but samples the line again halfway into

the bit to determine if it is a true Start Bit or false one. For false Start Bit detection, the ACIA does not begin to receive data; instead, only a true Start Bit initiates receiver operation.

- 7. Precautions to consider with the crystal oscillator circuit:
  - a) The external crystal should be a "series" mode crystal.
  - b) The XTALI input may be used as an external clock input. The unused pin (EXTAL0) must be floating and may not be used for any other function.
- DCD and DSR transitions, although causing immediate processor interrupts, have no effect on transmitter operation. Data will continue to be sent, unless the processor forces the transmitter to turn off. Since these are high-impedance inputs, they must not be permitted to float (unconnected). If unused, they must be terminated either to GND or VCC.

### GENERATION OF NON-STANDARD BAUD RATES

The internal counter/divider circuit selects the appropriate divisor for the crystal frequency by means of bits 0-3 of the ACIA Control Register. By using a different crystal, other baud rates may be generated. These can be determined by the baud rate = crystal frequency + divisor. Furthermore, it is possible to drive the ACIA with an off-chip oscillator to achieve other baud rates. In this case, XTALI (pin 6) must be the clock input and XTALO (pin 7) must be a no-connect.

# FIGURE 1. TRANSMITTER/RECEIVER CLOCK CIRCUITS





# FIGURE 2. CONTROL REGISTER

The Control Register is used to select the desired mode for the VL65(C)51. The word length, number of stop bits, and clock controls are defined below.

|                    |        |                    |                             |   | 7 |   |   |   |   |            |   |                        |
|--------------------|--------|--------------------|-----------------------------|---|---|---|---|---|---|------------|---|------------------------|
|                    |        |                    |                             | 7 | 6 | 5 | 4 | 3 | 2 | 1          | 0 |                        |
| STOP               | BITS   |                    |                             |   |   |   | 1 |   |   |            |   | BAUD RATE<br>GENERATOR |
| 0 =                | 1 Stop | o Bit              |                             |   |   |   |   | 0 | 0 | 0          | 0 | 16 x EXTERNAL CLOCK    |
| 1 =                | 2 Stop | o Bits             |                             |   |   |   |   | 0 | 0 | 0          | 1 | 50                     |
| [                  | 1 Stop | Bit if Word Lengt  | h = 8 Bits and Parity*      |   |   |   |   | 0 | 0 | <u>_</u> 1 | 0 | 75                     |
|                    | 1.5 St | op Bits if Word Le | ngth = 5 Bits and No Parity |   |   |   |   | 0 | 0 | 1          | 1 | 109.92                 |
|                    |        |                    |                             |   |   |   |   | 0 | 1 | 0          | 0 | 134.58                 |
| WOR                | DLEN   | IGTH               |                             |   |   | I |   | 0 | 1 | 0          | 1 | 150                    |
| BI                 | г      | DATA WORD          |                             |   |   |   |   | 0 | 1 | 1          | 0 | 300                    |
| 6                  | 5      | LENGTH             |                             |   |   |   |   | 0 | 1 | 1          | 1 | 600                    |
| 0                  | 0      | 8                  |                             |   |   |   |   | 1 | 0 | 0          | 0 | 1200                   |
| 0                  | 1      | 7                  |                             |   |   |   |   | 1 | 0 | 0          | 1 | 1800                   |
| 1                  | 0      | 6                  |                             |   |   |   |   | 1 | 0 | 1          | 0 | 2400                   |
| 1                  | 1      | 5                  |                             |   |   |   |   | 1 | 0 | 1          | 1 | 3600                   |
| ham, georgeologika |        | ·····              |                             |   |   |   |   | 1 | 1 | 0          | 0 | 4800                   |
| RECE               | IVER   | CLOCK SOURCE       | 1                           |   |   |   |   | 1 | 1 | 0          | 1 | 7200                   |
| 0 = F              |        | al Beceiver Clock  | 7                           |   |   |   |   | 1 | 1 | 1          | 0 | 9600                   |
| 1 = E              | Baud F | Rate Generator     |                             |   |   |   |   |   | 1 | 1          | 1 | 19,200                 |

\* This allows for 9-bit transmission (8 data bits plus parity).

|                | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------------|---|---|---|---|---|---|---|---|
| HARDWARE RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| PROGRAM RESET  | 1 | - | - | 1 | - | - | 1 | - |



### FIGURE 3. COMMAND REGISTER

The Command Register is used to control specific transmit/receive functions.



0 0

0 1

1 0

1 1

0

0 0

0 0

0 0 0 0

Disabled

Enabled

Disabled

Disabled

1 0

0

0

High

Low

Low

Low

Off

On

On

Transmit BRK

1 = Echo (Bits 2 and 3 must be "0")

6-50

7 6 5 4 3 2

0 0

HARDWARE RESET

PROGRAM RESET



# FIGURE 4. STATUS REGISTER

| 7 | 6 | 5 | 4 | 3 |   | 2 | 1                                       | 0 | ] |                                 |                                     |                                         |
|---|---|---|---|---|---|---|-----------------------------------------|---|---|---------------------------------|-------------------------------------|-----------------------------------------|
| Т | Τ | Τ | Τ |   |   | Τ | Τ                                       |   | • | STATUS                          | SET BY                              | CLEARED BY                              |
|   |   |   |   |   |   |   |                                         |   | - | Parity Error*                   | 0 = No Error<br>1 = Error           | Self Clearing **                        |
|   |   |   |   |   |   |   | L                                       |   | _ | Framing Error*                  | 0 = No Error<br>1 = Error           | Self Clearing**                         |
|   |   |   |   |   |   | L |                                         |   | - | Overrun*                        | 0 = No Error<br>1 = Error           | Self Clearing**                         |
|   |   |   |   |   | L |   |                                         |   | - | Receive Data<br>Register Full   | 0 = Not Full<br>1 = Full            | Read Receive<br>Data Register           |
|   |   |   | L |   |   |   |                                         |   | - | Transmit Data<br>Register Empty | 0 = Not Empty<br>1 = Empty          | Write Transfer<br>Data Register         |
|   |   | L |   |   |   |   |                                         |   | - | DCD                             | 0 = <u>DC</u> D Low<br>1 = DCD High | Not Resettable<br>Reflects DCD<br>State |
|   | L |   |   |   |   |   |                                         |   | - | DSR                             | 0 = <u>DSR</u> Low<br>1 = DSR High  | Not Resettable<br>Reflects DSR<br>State |
| L |   |   |   |   |   |   | .,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, |   | _ | ĪRQ                             | 0 = No Interrupt<br>1 = Interrupt   | Read<br>Status Register                 |

#### \* NO INTERRUPT GENERATED FOR THESE CONDITIONS.

\*\* CLEARED AUTOMATICALLY AFTER A READ OF RDR AND THE NEXT ERROR-FREE RECEIPT OF DATA.

|                | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
|----------------|---|---|---|---|---|---|---|---|--|
| HARDWARE RESET | 0 | - | - | 1 | 0 | 0 | 0 | 0 |  |
| PROGRAM RESET  |   | - | - | - | 1 | 0 | - | - |  |

BIT



# TABLE 1. TRANSMIT/RECEIVE CHARACTERISTICS TA = 0°C to +70°C, VCC = 5 V ±5%

|        |                        | VL65(C)51-01 |     | VL65(C)51-02 |     | VL650 | 51-03 | VL65C |     |      |
|--------|------------------------|--------------|-----|--------------|-----|-------|-------|-------|-----|------|
| Symbol | Parameter              | Min          | Max | Min          | Max | Min   | Max   | Min   | Max | Unit |
| TCYC   | T/R Clock Rate         | 400*         |     | 400*         |     | 400*  |       | 400*  | -   | μs   |
| тсн    | T/R Clock High Time    | 175          |     | 175          |     | 175   | -     | 175   | ·   | ns   |
| TCL    | T/R Clock Low Time     | 175          | —   | 175          |     | 175   |       | 175   |     | ns   |
| TDD    | XTL1 to TxD Prop. Dly. | -            | 500 | -            | 500 | -     | 330   | -     | 250 | ns   |
| TDLY   | Prop. Dly. (RTS, DTR)  |              | 500 | —            | 500 | -     | 330   | -     | 250 | ns   |
| TIRQ   | IRQ Prop. Dly.         | -            | 500 | -            | 500 | -     | 500   | -     | 500 | ns   |

TR, TF = 10 to 30 ns

The baud rate with external clocking is: Baud Rate = 1 + (16 X TCYC)

VL6551•VL65C51

|        |                     | VL65(C) | VL65(C)51-01 |     | VL65(C)51-02 |      | 51-03 | VL65C5 | 51-04 |      |
|--------|---------------------|---------|--------------|-----|--------------|------|-------|--------|-------|------|
| Symbol | Parameter           | Min     | Max          | Min | Max          | Min  | Max   | Min    | Max   | Unit |
| TCYC   | Cýcle Time          | 1.0     |              | 0.5 | -            | 0.33 |       | 0.25   | -     | μs   |
| тс     | Ø2 Pulse Width      | 470     | _            | 240 | -            | 160  |       | 120    |       | ns   |
| TACR   | Address Set-Up Time | 160     | -            | 90  | -            | 65   |       | 45     |       | ns   |
| TCAR   | Address Hold Time   | 0       | -            | 0   |              | 0    | _     | 0      | -     | ns   |
| TWCR   | R/W Set-Up Time     | 160     | -            | 90  | -            | 65   |       | 45     |       | ns   |
| TCDR   | Read Access Time    | _       | 200          | -   | 150          | -    | 120   | _      | 90    | ns   |
| THR    | Read Data Hold Time | 10      |              | 10  | -            | 10   |       | 10     | _     | ns   |
| THW    | Bus Active Time     | 40      |              | 40  | -            | 40   | _     | 40     | -     | ns   |

# TABLE 2. READ TIMING TA = 0°C to +70°C, VCC = 5 V $\pm$ 5%

TR, TF = 10 to 30 ns

FIGURE 6. READ TIMING (SEE TABLE 2)



|        |                      | VL65(C)51-01 |     | VL65(C)51-02 |     | VL65C51-03 |     | VL65C51-04 |     |      |
|--------|----------------------|--------------|-----|--------------|-----|------------|-----|------------|-----|------|
| Symbol | Parameter            | Min          | Max | Min          | Max | Min        | Max | Min        | Max | Unit |
| TCYC   | Cycle Time           | 1.0          | _   | 0.5          | -   | 0.33       |     | 0.25       |     | μs   |
| TC     | Ø2 Pulse Width       | 470          | _   | 240          |     | 160        | _   | 120        |     | ns   |
| TACW   | Address Set-Up Time  | 160          | _   | 90           |     | 65         | _   | 45         |     | ns   |
| TCAH   | Address Hold Time    | 0            | _   | 0            |     | 0          | _   | 0          | -   | ns   |
| TWCW   | R/W Set-Up Time      | 160          |     | 90           | _   | 65         |     | 45         | _   | ns   |
| тсwн   | R/W Hold Time        | 0            | _   | 0            | -   | 0          |     | 0          | -   | ns   |
| TDCW   | Data Bus Set-Up Time | 195          | _   | 90           |     | 65         |     | 45         | _   | ns   |
| THW    | Data Bus Hold Time   | 10           |     | 10           | _   | 10         | _   | 10         | _   | ns   |

# TABLE 3. WRITE TIMING TA = 0°C to +70°C, VCC = 5 V $\pm$ 5%

TR, TF = 10 to 30 ns

FIGURE 7. WRITE TIMING (SEE TABLE 3)





# FIGURE 8. TRANSMIT TIMING (SEE TABLE 1)



NOTE: TxD RATE IS 1/16 TxC RATE.

FIGURE 9. INTERRUPT TIMING (SEE TABLE 1)



### FIGURE 10. RECEIVE EXTERNAL CLOCK TIMING (SEE TABLE 1)



NOTE: RxD RATE IS 1/16 RxC RATE.



FIGURE 11. TEST LOADS

VL6551•VL65C51

#### Symbol Unit Conditions Characteristic Min Тур Max v VIN = 0 to 5 V VCC VIH 2.0 \_\_\_\_ Input HIGH Voltage v VIL Input LOW Voltage -0.3 0.8 \_\_\_\_\_ Input Leakage Current: (Ø2, R/W, RES, CS0, IIN ±1.0 $\pm 2.5$ μA -----CS1 BS0: BS1. CTS. RxD, DC DDSR) ITSI ±2.0 ±10.0 μA Input Leakage Current for High Imped. \_\_\_\_\_ Output HIGH Voltage: VOH v $ILOAD = -100 \mu A$ 2.4 (DB0 - DB7, TxD, RxC, RTS, DTR) Output LOW Voltage: VOL ILOAD = I.6 mAv \_\_\_\_ \_\_\_\_ 0.4 (DB0 - DB7, TxD, RxC, RTS, DTR, IRQ) Output HIGH Current (Sourcing): IOH -100 μA VOH = 2.4 V\_ (DB0 - DB7, TxD, RxC, RTS, DTR) Output LOW Current (Sinking): VOL = 0.4 V IOL VOH = 2.4 V mA 1.6 \_ \_ (DB0 - DB7, TxD, RxC, RTS, DTR, IRQ) IOFF Output Leakage Current (Off State): VOUT = 5V (IRQ) 1.0 10.0 μA ...... CCLK рF 20 Clock Capacitance (Ø2) \_\_\_\_ \_ CIN 10 рF Input Capacitance (Except XTAL1 and XTAL2) \_\_\_\_ \_ COUT 10 pF **Output Capacitance** \_\_\_\_ \_\_\_\_ PD Power Dissipation (See Graph) (TA = 0°C) 170 300 mW VCC = 5.25 V \_\_\_\_

# DC CHARACTERISTICS (VL6551) TA = 0°C to +70°C, VCC = 5 V ±5%, unless otherwise noted.

# FIGURE 12. HMOS POWER DISSIPATION VS. TEMPERATURE



VL6551•VL65C51

| DC CHARACTERISTICS (VL65C | 51) TA = 0°C to +70°C, VCC = 5 V $\pm$ 5%, unless otherwise noted. |
|---------------------------|--------------------------------------------------------------------|
|---------------------------|--------------------------------------------------------------------|

| Symbol | Characteristic                                                                                 | Min  | Тур  | Мах   | Unit     | Conditions      |
|--------|------------------------------------------------------------------------------------------------|------|------|-------|----------|-----------------|
| VIH    | Input HIGH Voltage                                                                             | 2.0  | -    | vcc   | V        | VIN = 0 to 5 V  |
| VIL    | Input LOW Voltage                                                                              | -0.3 | -    | 0.8   | V        |                 |
| liN    | Input Leakage Current: (Ø2, R <mark>/W, RES,</mark> CS0,<br>CS1, RS0; RS1, CTS, RxD, DC D/DSR) | -    | ±1.0 | ±2.5  | μA       | t.              |
| ITSI   | Input Leakage Current for High Imped.                                                          |      | ±2.0 | ±10.0 | μΑ       |                 |
| VOH    | Output HIGH Voltage:<br>(DB0 – DB7, TxD, RxC, RTS, DTR)                                        | 2.4  | —    |       | <b>V</b> | ILOAD = -100 μΑ |
| VOL    | Output LOW Voltage:<br>(DB0 – DB7, TxD, RxC, RTS, DTR, IRQ)                                    |      |      | 0.4   | v        | ILOAD = I.6 mA  |
| ЮН     | Output HIGH Current (So <u>urcing):</u><br>(DB0 – DB7, TxD, RxC, RTS, DTR)                     | -200 | _    |       | μA       | VOH = 2.4 V     |
| IOL    | Output LOW Current (Sinking): VOL = 0.4 V<br>(DB0 – DB7, TxD, RxC, RTS, DTR, IRO)              | 1.6  |      | ·     | mA       | VOH = 2.4 V     |
| IOFF   | Output Leakage Current (Off State): VOUT = 5 V (IRQ)                                           | ·    | 1.0  | 10.0  | μA       |                 |
| CCLK   | Clock Capacitance (Ø2)                                                                         | -    | —    | 20    | pF       |                 |
| CIN    | Input Capacitance (Except XTAL1 and XTAL2)                                                     |      |      | 10    | pF       |                 |
| COUT   | Output Capacitance                                                                             |      | _    | 10    | pF       |                 |
| PD     | Power Dissipation (TA = 0°C)                                                                   | _    | 7    | 10    | mW/MHz   | VCC = 5.25 V    |

FIGURE 13. CLOCK GENERATION



# **ABSOLUTE MAXIMUM RATINGS**

 Supply Voltage
 -0.3 V to +7.0 V

 Input/Output Voltage
 -0.3 V to +7.0 V

 Operating Temperature
 0°C to 70°C

 Storage Temperature
 -55°Cto 150°C

All inputs contain protection circuitry to prevent damage to high static charges. Care should be exercised to prevent unnecessary application of voltages in excess of the allowable limits.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.

# VL8530



# SERIAL COMMUNICATIONS CONTROLLER (SCC)

# FEATURES

- Two independent full-duplex channels
- 0 to 1.5M bit/second
- Multi-protocol operation for NRZ, NRZI, or FM
- Asynchronous mode includes 1, 1.5, or 2 stop bits per character.
- Programmable clock factor
- Break generation and error detection
- Intelligent SDLC/HDLC
- Local loopback and auto echo modes
- Synchronous support includes internal or external character synchronization.

# **PIN DIAGRAM**



# DESCRIPTION

The VL8530 Serial Communications Controller (SCC) is a dual-channel, multiprotocol data communications peripheral designed for use with conventional non-multiplexed buses. The SCC can be software-configured to satisfy a wide variety of serial communications applications. The device contains a variety of new, sophisticated internal functions, including on-chip baud rate generators, digital phase-locked loops, and crystal oscillators that dramatically reduce the need for external logic. The SCC handles asynchronous formats, synchronous byte-oriented protocols, such as IBM Bisync, and synchronous bit-oriented protocols, such as HDLC and IBM SDLC. This versatile device supports virtually any serial data transfer application (cassette, diskette, tape drives, etc.).

The device can generate and check CRC codes in any synchronous mode and can be programmed to check data integrity in various modes. The SCC also has facilities for modem controls in both channels.



| ORDER INFORMATION |                    |                             |  |  |  |  |
|-------------------|--------------------|-----------------------------|--|--|--|--|
| Part<br>Number    | Clock<br>Frequency | Package                     |  |  |  |  |
| VL8530-04PC       |                    | Plastic DIP                 |  |  |  |  |
| VL8530-04QC       | 4 MHz              | Plastic Leaded Chip Carrier |  |  |  |  |
| VL8530-04CC       |                    | Ceramic DIP                 |  |  |  |  |
| VL8530-06QC       |                    | Plastic DIP                 |  |  |  |  |
| VL8530-06PC       | 6 MHz              | Plastic Leaded Chip Carrier |  |  |  |  |
| VL8530-06CC       |                    | Ceramic DIP                 |  |  |  |  |

Note: Operating temperature range: 0° to +70°C.





# SIGNAL DESCRIPTIONS

| Signal<br>Name       | DIP Pin<br>Number       | Signal<br>Description                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A∕B                  | 34                      | Channel A/Channel B Select - This input signal selects the channel on which the read or write operation occurs.                                                                                                                                                                                                                                                                                                     |
| C/E                  | 33                      | Chip Enable - This active-LOW input signal selects the SCC for a read or write operation.                                                                                                                                                                                                                                                                                                                           |
| CTSA,<br>CTSB        | 18<br>22                | Clear To Send-Active-LOW inputs- If these pins are programmed as auto enables, a LOW<br>on the inputs enables the respective transmitters. If not programmed as auto enables,<br>they may be used as general-purpose inputs. Both inputs are Schmitt-trigger buffered to<br>accommodate slow rise-time inputs. The SCC detects pulses on these inputs and can<br>interrupt the CPU on both logic level transitions. |
| D/C                  | 32                      | Data/Control Select - This input signal defines the type of information transferred to or<br>from the SCC. A HIGH means data is transferred; a LOW indicates a command.                                                                                                                                                                                                                                             |
| DCDA,<br>DCDB        | 19<br>21                | Data Carrier Detect-Active-LOW inputs- These pins function as receiver enables if they<br>are programmed for auto enables; otherwise, they may be used as general-purpose input<br>pins. Both pins are Schmitt-trigger buffered to accomodate slow rise-time signals. The<br>SCC detects pulses on these pins and can interrupt the CPU on both logic level<br>transitions.                                         |
| D0-D7                | 40,1,39,2,38,<br>3,37,4 | Data Bus - These bidirectional, 3-state lines carry data and commands to and from the SCC.                                                                                                                                                                                                                                                                                                                          |
| DTR/REQA<br>DTR/REQB | 16,<br>24               | Data Terminal Ready/Request - These active-LOW outputs follow the state programmed<br>into the DTR bit. They can also be used as general-purpose outputs or as request lines for<br>a direct memeory access (DMA) controller.                                                                                                                                                                                       |
| IEI                  | 7                       | Interrupt Enable In-Active-HIGH output- IEI is used with IEO to form an interrupt daisy<br>chain when there is more than one interrupt-driven device. A HIGH IEI indicates that no<br>other higher priority device has an interrupt underservice or is requesting an interrupt.                                                                                                                                     |
| IEO                  | 6                       | Interrupt Enable Out-Active-HIGH output - IEO is HIGH only if IEI is HIGH and the CPU is<br>not servicing an SCC interrupt or the SCC is not requesting an interrupt (Interrupt<br>Acknowledge cycle only). IEO is connected to the next lower priority device's IEI input<br>and thus inhibits interrupts from lower priority devices.                                                                             |



# SIGNAL DESCRIPTIONS (CONTINUED)

| Signal<br>Name    | DIP Pin<br>Number | Signal<br>Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INT               | 5                 | Interrupt Request-Active-LOW open-drain output- This signal is activated when the SCC requests an interrupt.                                                                                                                                                                                                                                                                                                                                                                                                    |
| INTACK            | 8                 | Interrupt Acknowledge-Active-LOW input- This signal indicates an active Interrupt<br>Acknowledge cycle. During this cycle, the SCC interrupt daisy chain settles. When RD be-<br>comes active, the SCC places an interrupt vector on the data bus (if IEI is HIGH). The<br>INTACK signal is latched by the rising edge of PCLK.                                                                                                                                                                                 |
| PCLK              | 20                | Clock - This input is the master SCC clock used to synchronize internal signals. PCLK is a TTL-level signal.                                                                                                                                                                                                                                                                                                                                                                                                    |
| RD                | 36                | Read-Active-LOW input - This signal indicates a read operation and, when the SCC is<br>selected, enables the SCC's bus drivers. During the Interrupt Acknowledge cycle, this<br>signal gates the interrupt vector onto the bus if the SCC is the highest priority device<br>requesting an interrupt.                                                                                                                                                                                                            |
| RxDA,<br>RxDB     | 13,<br>27         | Receive Data-Active-HIGH inputs- These input signals receive serial data at standard TTL levels.                                                                                                                                                                                                                                                                                                                                                                                                                |
| RTxCA,<br>RTxCB   | 12,<br>28         | Receive/Transmit Clocks-Active-LOW inputs - <u>These</u> pins can be programmed in several different modes of operation. In each channel, <u>RTxC</u> may supply the receive clock, the transmit clock, the clock for the baud rate generator, or the clock for the digital <u>phase</u> locked loop. These pins can also be programmed for use with the respective SYNC pins as a crystal oscillator. The receive clock may be 1, 16, 32, or 64 times the data rate in asynchronous modes.                     |
| RTSA,<br>RTSB     | 17,<br>23         | Request To Send-Active-LOW outputs - When the request-to-send ( $\overline{\text{RTS}}$ ) bit in write register 5 (figure 7) is set, the $\overline{\text{RTS}}$ signal goes LOW. When the RTS bit is reset in the asynchronous mode and auto enable is on, the signal goes HIGH after the transmitter is empty. In synchronous mode or in asynchronous mode with auto enable off, the RTS pin strictly follows the state of the $\overline{\text{RTS}}$ bit. Both pins can be used as general-purpose outputs. |
| SYNCA,<br>SYNCB   | 11,<br>29         | Synchronization-Active-LOW inputs or outputs - These pins can act either as inputs or outputs, or part of the crystal oscillator circuit. In the asynchronous receive mode (crystal oscillator option not selected), these pins are inputs similar to CTS and DCD. In this mode, transitions on these lines affect the state of the synchronous/hunt status bits in read register 0 (Figure 6) but have no other function.                                                                                      |
|                   |                   | In external synchronization mode with the crystal oscillator not selected, these lines also<br>act as inputs. In this mode, SYNC must be driven LOW to receive clock cycles after the<br>last bit in the synchronous character is received. Character assembly begins on the<br>rising edge of the receive clock immediately preceding the activation of SYNC.                                                                                                                                                  |
|                   |                   | In the internal synchronization mode (Monosync and Bisync) with the crystal oscillator not<br>selected, these pins act as outputs and are active only during the part of the receive<br>clock cycle in which synchronous characters are recognized. The synchronous condi-<br>tion is not latched, so these outputs are active each time a synchronization pattern is<br>recognized (regardless of character boundaries). In SDLC mode, these pins act as<br>outputs and are valid on receipt of a flag.        |
| TxDA,<br>TxDB     | 15,<br>25         | Transmit Data-Active-HIGH outputs - These output signals transmit serial data at standard TTL levels.                                                                                                                                                                                                                                                                                                                                                                                                           |
| TRxCA,<br>TRxCB   | 14,<br>26         | Transmit/Receive Clocks-Active-LOW inputs or outputs - These pins can be programmed<br>in several different modes of operation. TRxC may supply the receive clock or the<br>transmit clock in the input mode or supply the output of the digital phase-locked loop, the<br>crystal oscillator, the baud rate generator, or the transmit clock in the output mode.                                                                                                                                               |
| WR                | 35                | Write-Active-LOW input - When the SCC is selected, this signal indicates a write operation. The coincidence of RD and WR is interpreted as a reset.                                                                                                                                                                                                                                                                                                                                                             |
| W/REQA,<br>W/REQB | 10,<br>30         | Wait/Request-open-drain outputs when programmed for a wait function, driven HIGH or<br>LOW when programmed for a Request function) - These dual-purpose outputs may be<br>programmed as Request lines for a DMA controller or as Wait lines to synchronize the CPU<br>to the SCC data rate. The reset state is Wait                                                                                                                                                                                             |



# FUNCTIONAL DESCRIPTION

The functional capabilities of the SCC can be described from two different points of view. As a data communications device, it transmits and receives data in a wide variety of data communications protocols. As a microprocessor peripheral, the SCC

FIGURE 1. SCC PROTOCOLS

offers SUCH valuable features as vectored interrupts, polling, and simple handshake capability.

# DATA COMMUNICATIONS CAPABILITY

The SCC provides two independent fullduplex channels programmable for use in any common asynchronous or synchronous data communication protocol. Figure 1 and the following description briefly detail these protocols.

Asynchronous modes - Transmission and reception can be accomplished independently on each channel with 5 to 8 bits per character, plus optional





even or odd parity. The transmitters can supply 1, 1 1/2, or 2 stop bits per character and can provide a break output at any time. The receiver breakdetection logic interrupts the CPU both at the start and at the end of a received break.

Reception is protected from spikes by a transient spike-rejection mechanism that checks the signal one-half a bit time after a LOW level is detected on the receive data input (RxDA or RxDB). If the LOW does not persist (as in the case of a transient), the character assembly process does not start.

Framing errors and overrun errors are detected and buffered together with the partial character on which they occur. Vectored interrupts allow fast servicing or error conditions using dedicated routines. Furthermore, a built-in checking process avoids the interpretation of a framing error as a new start bit: a framing error results in the addition of one-half a bit time to the point at which the search for the next start bit begins.

The SCC does not require symmetric transmit and receive clock signals a feature allowing use of the wide variety of clock sources. The transmitter and receiver can handle data at a rate of 1, 1/16, 1/32, or 1/64 of the clock rate supplied to the receive and transmit clock inputs. In asynchronous modes, the SYNC pin may be programmed as an input used for such functions as monitoring a ring indicator.

Synchronous modes. The SCC supports both byte-oriented and bitoriented synchronous communication. Synchronous byte-oriented protocols can be handled in several modes, allowing character synchronization with a 6-bit or 8-bit synchronous character (Monosync) any 12-bit synchronization pattern (Bisync), or with an external synchronous signal. Leading sync characters can be removed without interrupting the CPU. 5- or 7-bit synchronous characters are detected with 8- or 16-bit patterns in the SCC by overlapping the larger pattern across multple incoming synchronous characters.

The CRC checking for synchronous byte-oriented modes is delayed by one character time so that the CPU may disable CRC checking on specific characters. This permits the implementation of such protocols as IBM Bisync.

Both CRC-16 (X<sup>16</sup> + X<sup>15</sup> + X<sup>2</sup> + 1) and CCITT (X16 + X12 + X5 + 1) error checking polynomials are supported. Either polynomial may be selected in all Synchronous modes. Users may preset the CRC generator and checker to all ones or all zeros. The SCC also pro-vides a feature that automatically transmits CRC data when no other data is available for transmission. This allows for high-speed transmissions under DMA control, with no need for CPU intervention at the end of a message. When there is no data or CRC to send in synchronous modes, the transmitter inserts 6-, 8-, or 16-bit synchronous characters, regardless of the programmed character length.

The SCC supports synchronous bitoriented protocols, such as SDLC and HDLC, by performing automatic flag sending, zero insertion, and CRC generation. A special command can be used to abort a frame in transmission. At the end of a message, the SCC automatically transmits the CRC and trailing flag when the transmitter underruns. The transmitter may also be programmed to send an idle line consisting of continuous flag characters or a steady marking condition.

If a transmit underrun occurs in the middle of a message, an external/status interrupt warns the CPU of this status change so that an abort may be issued. The SCC may also be programmed to send an abort itself in case of an underrun, relieving the CPU of this task. One to eight bits per character can be sent, allowing reception of a message with no prior information about the character structure in the information field of a frame.

The receiver automatically acquires synchronization on the leading flag of a frame in SDLC or HDLC and provides a synchronization signal on the SYNC pin (an interrupt can also be programmed). The receiver can be programmed to search for frames addressed by a single byte (or four bits within a byte) of a user-selected address or to a global broadcast address. In this mode, frames not matching either the user-selected or broadcast address are ignored. The number of address bytes can be extended under software control. For receiving data, an interrupt on the first received character, or an interrupt on every character, or on special condition only (end-of-frame) can be selected. The receiver automatically deletes all zeros inserted by the transmitter during character assembly. The CRC is also calculated and is automatically checked to validate frame transmission. At the end of transmission, the status of a received frame is availabe in the status registers. In SDLC mode, the SCC must be programmed to use the SDLC CRC polynomial, but the generator and checker may be preset to all ones or all zeros

The CRC is inverted before transmission and the receiver checks against the bit pattern 0001110100001111.

The NRZ, NRZI, or FM coding may be used in any 1x mode. The parity options available in asynchronous modes are available in synchronous modes.

The SCC can be conveniently used under DMA control to provide highspeed reception or transmission. In reception, for example, the SCC can interrupt the CPU when the first character of a message is received. The CPU then enables the DMA to transfer the message to memory. The SCC then issues an end-of-frame interrupt and the CPU can check the status of the received messsage.



Thus, the CPU is freed for other service while the message is being received. The CPU may also enable the DMA first and have the SCC interrupt only on end-of-frame. This procedure allows all data to be transferred via the DMA.

# SDLC LOOP MODE

The SCC supports SDLC loop mode in addition to normal SDLC. In an SDLC loop, there is a primary controller station that manages the message traffic flow on the loop and any number of secondary stations. In SDLC loop mode, the SCC performs the functions of a secondary station while an SCC operating in regular SDLC mode can act as a controller (Figure 3).

A secondary station in an SDLC Loop is always listening to the messages being sent around the loop, and in fact must pass these messages to the rest of the loop by retransmitting them with a one-bit time delay. The secondary station can place its own message on the loop only at specific times. The controller signals that secondary stations may transmit messages by sending a special character, called an End Of Poll (EOP), around the loop. The EOP character is the bit pattern 11111110. Because of zero insertion during messages, this bit pattern is unique and easily recognized.

FIGURE 2. DETECTING 5- OR 7-BIT SYNCHRONOUS CHARACTERS

When a secondary station has a message to transmit and recognizes an EOP on the line, it changes the last binary 1 of the EOP to a 0 before transmission. This has the effect of turning the EOP into a flag sequence. The secondary station now places its message on the loop and terminates the message with an EOP. Any secondary stations further down the loop with messages to transmit can then append their messages to the message of the first secondary station without messages to send merely echo the incoming messages and are prohibited from placing messages on the loop (except upon recognizing an EOP).

The SDLC loop mode is a programmable option in the SCC. NRZ, NRZI, and FM coding may all be used in SDLC Loop mode.

BAUD RATE GENERATOR Each channel in the SCC contains a programmable baud rate generator. Each generator consists of two 8-bit time-constant registers that form a 16bit time constant, a 16-bit down counter, and a flip-flop on the output producing a square wave. On startup, the flip-flop on the output is set in a HIGH state, the value in the time constant register is loaded into the counter, and the counter starts counting down. The output of the baud generator toggles upon reaching 0, the value in the time constant register is loaded into the counter, and the

process is repeated. The time constant may be changed at any time, but the new value does not take effect until the next load of the counter.

The output of the baud rate generator may be used as either the transmit clock, the receive clock, or both. It can also drive the digital phase-locked loop (see next section).

If the receive clock or transmit clock is not programmed to come from the TRxC pin, the output of the baud rate generator may be echoed out via the TRxC pin.

The following formula relates the time constant to the baud rate (the baud rate is in bits/second and BR clock period is in seconds):

baud rate =

2 (time constant+2) x (BR clock period)

# DIGITAL PHASE-LOCKED

The SCC contains a digital phaselocked-loop (DPLL) to recover clock information from a data stream with NRZI or FM encoding. The DPLL is driven by a clock that is nominally 32 (NRZI) or 16 (FM) times the data rate. The DPLL uses this clock, along with the data stream, to construct a clock for the data. This clock may then be used as the SCC receive clock, the transmit clock, or both.

SECONDARY #

SECONDARY #

### FIGURE 3. AN SDLC LOOP





For NRZI encoding, the DPLL counts the 32x clock to create nominal bit times. As the 32x clock is counted, the DPLL is searching the incoming data stream for edges (either 1 to 0 or 0 to 1). Whenever an edge is detected, the DPLL makes a count adjustment (during the next counting cycle), producing a terminal count closer to the center of the bit cell.

For FM encoding, the DPLL still counts from 0 to 31, but with a cycle corresponding to two bit times. When the DPLL is locked, the clock edges in the data stream should occur between counts 15 and 16, and between counts 31 and 0. The DPLL looks for edges only during a time centered on the 15 to 16 counting transition.

The 32x clock for the DPLL can be programmed to come from either the RTxC input or the output of the baud rate generator. The DPLL output may be programmed to be echoed out of the SCC via the TRxC pin (if this pin is not being used as an input).

# DATA ENCODING

The SCC may be programmed to encode and decode the serial data in four different ways (Figure 4). In NRZ encoding, a 1 is represented by a HIGH level and a 0 is represented by a LOW level. In NRZI encoding, a 1 is represented by no change in level and a 0 is represented by a change in level.

In FM1 (more properly, bi-phase mark), a transition occurs at the beginning of every bit cell. A 1 is represented by an additional transition at the center of the bit cell and a 0 is represented by no additional transition at the center of the bit cell. In FMØ (bi-phase space), a transition occurs at the beginning of every bit cell. A 0 is represented by an additional transition at the center of the bit cell, and a 1 is represented by no additional transition at the center of the bit cell.

in addition to these four methods, the SCC can be used to decode Manchester (bi-phase level) data by using the DPLL in the FM mode and programming the receiver for NRZ data. Manchester encoding always produces a transition at the center of the bit cell. If the transition is 0 to 1, the bit is a 0. If the transition is 1 to 0, the bit is a 1.

### AUTO ECHO AND LOCAL LOOPBACK

The SCC is capable of automatically echoing everything it receives. This feature is useful mainly in asynchronous modes, but works in synchronous and SDI C modes as well. In auto echo mode, TxD is RxD. Auto Echo mode can be used with NRZI or FM encoding with no additional delay. because the data stream is not decoded before retransmission. In auto echo mode, the CTS input is ignored as a transmitter enable (although transitions on this input can still cause interrupts if programmed to do so). In this mode, the transmitter is actually bypassed and the programmer is responsible for disabling transmitter interrupts and Wait/Request on transmit.

The SCC is also capable of local loopback. In this mode TxD is RxD, just as in auto echo mode. However, in local loopback mode, the internal transmit data is tied to the internal receive data and RxD is ignored (except to be echoed out via TxD). The CTS and DCD inputs are also ignored as transmit and receive enables. However, transitions on these inputs can still cause interrupts. Local Loopback works in asynchronous, synchronous and SDLC modes with NRZ, NRZI or FM coding of the data stream.

### **I/O INTERFACE CAPABILITIES**

The SCC offers the choice of polling, interrupt (vectored or nonvectored), and block transfer modes to transfer data, status, and control information to and from the CPU. The block transfer mode can be implemented under CPU or DMA control.

# POLLING

All interrupts are disabled. Three status registers in the SCC are automatically updated whenever any function is performed . For example, end-of-frame in SDLC mode sets a bit in one of these status registers. The idea behind polling is for the CPU to periodically read a status register until the register contents indicate the need for data to be transferred. Only one register needs to be read; depending on its contents, the CPU either writes data, reads data, or continues. Two bits in the register indicate the need for data transfer.



# FIGURE 4. DATA ENCODING METHODS



An alternative is a poll of the Interrupt Pending register to determine the source of an interrupt. The status for both channels resides in one register.

# INTERRUPTS

When an SCC responds to an Interrupt Acknowledge signal (INTACK) from the CPU, an interrupt vector may be placed on the data bus. This vector is written in Write Register 2 (WR2) and may be read in Read Register 2A (RR2A) or Read Register 2B (RR2B) (Figures 6 and 7).

To speed interrupt response time, the SCC can modify three bits in this vector to indicate status. If the vector is read in Channel A, status is never included; if it is read in Channel B, status is always included.

Each of the six sources of interrupts in the SCC (Transmit, Receive, and External/Status interrupts in both channels) has three bits associated with the interrupt source: Interrupt Pending (IP), Interrupt Under Service (IUS), and Interrupt Enable (IE). Operation of the IE bit is straightforward. If the IE bit is set for a given interrupt source, that source can request interrupts. The exception is when the MIE (Master Interrupt Enable) bit in WR9 is reset and no interrupts may be requested. The IE bits are write only.

The other two bits are related to the interrupt priority chain (Figure 5). As a microprocessor peripheral, the SCC may request an interrupt only when no higher priority device is requesting one; e.g., when IEI is HIGH. If the device in question requests an interrupt, it pulls

down INT. The CPU then responds with INTACK, and the interrupting device places the vector on the data bus.

In the SCC, the IP bit signals a need for interrupt servicing. When an <u>IP</u> bit is 1 and the IEI input is HIGH, the INT output is pulled LOW, requesting an interrupt. In the SCC, if the IE bit is not set by enabling interrupts, then the IP for that source can never be set. The IP bits are readable in RR3A.

The IUS bits signal that an interrupt request is being serviced. If an IUS is set, all interrupt sources of lower priority in the SCC and external to the SCC are prevented from requesting interrupts. The internal interrupt sources are inhibited by the state of the internal daisy chain, while lower priority devices are inhibited by the IEO output of the SCC being pulled LOW and propagated to subsequent peripherals. An IUS bit is set during an interrupt acknowledge cycle if there are no higher priority devices requesting interrupts.

There are three types of interrupts: transmit, receive, and external/status. Each interrupt type is enabled under program control with Channel A having higher priority than Channel B, and with receive, transmit, and external/status interrupts prioritized in that order within each channel. When the transmit interrupt is enabled, the CPU is interrupted when the transmit buffer becomes empty. (This implies that the transmitter must have had a data character written into it so that it can become empty.) When enabled, the receiver can interrupt the CPU in one of three ways:

- On first receive character or special receive condition
- On all receive characters or special receive condition
- · On special receive condition only

Interrupt on first character or special condition and interrupt on special condition only are typically used with the block transfer mode. A special receive condition is one of the following: receiver overrun, framing error in asynchronous mode, end-of-frame in SDLC mode and, optionally, a parity error. The special receive condition interrupt is different from an ordinary receive character interrupt only in that the status is placed in the vector during the interrupt acknowledge cycle. In interrupt on first receive character, an interrupt can occur from special receive conditions any time after the first receive character interrupt.

The main function of the external/status interrupt is to monitor the signal transitions of the CTS, DCD, and SYNC pins; however, an external/status interrupt is also caused by a transmit underrun condition, or a zero count in the baud rate generator, or by the detection of a break (asynchronous mode), Abort (SDLC mode) or EOP (SDLC loop mode) sequence in the data stream.







The interrupt caused by the abort or EOP has a special feature allowing the SCC to interrupt when the abort or EOP sequence is detected or terminated. This feature facilitates the proper termination of the current message, correct initialization of the next message, and the accurate timing of the Abort condition in external logic in SDLC mode. in SDLC ioop mode, this feature allows secondary stations to recognize the wishes of the primary station to regain control of the loop during a poll sequence.

**CPU/DMA BLOCK TRANSFER** 

The SCC provides a block transfer mode to accommodate CPU block transfer functions and DMA controllers. The block transfer mode uses the Wait/Request output in conjunction with the Wait/Request bits in WR1. The Wait/Request output can be defined under software control as a WAIT line in the CPU Block Transfer mode or as a REQUEST line in the DMA block bransfer mode.

To a DMA controller, the SCC REQUEST output indicates that the SCC is ready to transfer data to or from memory. To the CPU, the WAIT line indicates that the SCC is not ready to transfer data, thereby requesting that the CPU extend the I/O cycle. The DTR/REQUEST line allows full-duplex operation under DMA control.

# PROGRAMMING

The SCC contains 13 write registers in each channel that are programmed by the system separately to configure the functional personality of the channels.

In the SCC, register addressing is direct for the data registers only, which are selected by a HIGH on the D/C pin. In all other cases (with the exception of WR0 and RR0), programming the write registers requires two write operations and reading the read registers requires both a write and a read operation. The first write is to WR0 and contains three bits that point to the selected register. The second write is the actual control word for the selected register, and if the second operation is read, the selected read register is accessed. All of the registers in the SCC, including the data registers, may be accessed in this fashion. The pointer bits are automatically cleared after the read or write operation so that WR0 (or RR0) is addressed again.

The system program first issues a series of commands to initialize the basic mode of operation. This is followed by other commands to qualify conditions within the selected mode. For example, the asynchronous mode, character length, clock rate, number of stop bits, and even or odd parity might be set first. Then the interrupt mode would be set, and, finally, receiver or trans-mitter enable.

# **READ REGISTERS**

The SCC contains eight read registers (nine counting receive buffer RR8) in each channel. Four of these may be read to obtain status information (RR0, RR1, RR10, and RR15). Two registers (RR12 and RR13) may be read to learn the baud rate generator time constant. The RR2 contains either the unmodified interrupt vector (Channel A) or the vector modified by status information (Channel B). The RR3 contains the Interrupt Pending (IP) bits (Channel A). Figures 6 through 13 show the formats for each read register.

The status bits of RR0 and RR1 are carefully grouped to simplify status monitoring; e.g., when the interrupt vector indicates a special receive Condition interrupt, all the appropriate error bits can be read from a single register (RR1).

# WRITE REGISTERS

The SCC contains 13 write registers (14 counting the WR8 transmit buffer) in each channel. These write registers are programmed separately to configure the functional personality of the channels. In addition, there are two registers (WR2 and WR9) shared by the two channels that may be accessed through either of them; WR2 contains the interrupt vector for both channels, while WR9 contains the interrupt control bits. Figures 14 through 28 show the format of each write register.

# TIMING

The SCC generates internal control signals from WR and RD that are related to PCLK. Since PCLK has no phase relationship with WR and RD, the circuitry generating these internal control signals must provide time for metastable conditions to disappear. This gives rise to a recovery time related to PCLK. The recovery time applies only between bus transactions involving the SCC. The recovery time required for proper operation is specified from the rising edge of WR or RD in the first transaction involving the SCC, to the falling edge of WR or RD in the second transaction involving the SCC. This time

must be at least six PCLK cycles plus 200 ns.

# **READ CYCLE TIMING**

Figure 29 illustrates Read cycle timing. Addresses on A/B and D/C and the status on INTACK must remain stable through the cycle. If CE falls after RD falls, or if it rises before RD rises, the effective RD is shortened.

# WRITE CYCLE TIMING

Figure 30 illustrates Write cycle timing. Addresses on <u>AB</u> and D/C and the status on INTACK must <u>remain</u> stable throughout the cycle. If CE falls after WR falls, or if it rises before WR rises, the effective WR is shortened.

# INTERRUPT ACKNOWLEDGE CYCLE TIMING

Figure 31 illustrates Interrupt Acknowledge cycle timing. Between the time INTACK goes LOW and the falling edge of RD, the internal and external IEI/IEO daisy chains settle. If there is an interrupt pending in the SCC and IEI is HIGH when RD falls, the Acknowledge cycle is intended for the SCC. In this case, the SCC may be programmed to respond to RD LOW by placing its interrupt vector on D0-D7, and it then internally sets the appropriate Interrupt-Under-Service latch.



### FIGURE 6. READ REGISTER 0



### FIGURE 11. READ REGISTER 12

0

0

n

LOOP SENDING

TWO CLOCKS MISSING

ONE CLOCK MISSING



### FIGURE 12. READ REGISTER 13



# FIGURE 13. READ REGISTER 15



# FIGURE 7. READ REGISTER 1

### FIGURE 8. READ REGISTER 2



# FIGURE 9. READ REGISTER 3





### FIGURE 14. WRITE REGISTER 0



# FIGURE 15. WRITE REGISTER 1



# FIGURE 16. WRITE REGISTER 2



### FIGURE 17. WRITE REGISTER 3



# FIGURE 18. WRITE REGISTER 4



# FIGURE 19. WRITE REGISTER 5





### FIGURE 20. WRITE REGISTER 6



# FIGURE 21. WRITE REGISTER 7





### FIGURE 22. WRITE REGISTER 9



# FIGURE 23. WRITE REGISTER 10



# FIGURE 24. WRITE REGISTER 11



### FIGURE 25. WRITE REGISTER 12



- BREAK/ABORT IE



# FIGURE 29. READ CYCLE TIMING



FIGURE 30. WRITE CYCLE TIMING



# FIGURE 31. INTERRUPT ACKNOWLEDGE CYCLE TIMING







FIGURE 33. READ AND WRITE TIMING (SEE TABLE 1)











# TABLE 1. READ AND WRITE TIMING

| No.       | Symbol     | Parameter                          | 4MH           | lz                                          | 6MHz     |        |          |
|-----------|------------|------------------------------------|---------------|---------------------------------------------|----------|--------|----------|
|           | ÷*         |                                    | Min           | Мах                                         | Min      | Max    | Notes    |
| 1         | TwPCI      | PCLK LOW Width                     | 105           | 2000                                        | 70       | 1000   |          |
| 2         | TwPCh      | PCLK HIGH Width                    | 105           | 2000                                        | 70       | 1000   |          |
| 3         | TfPC       | PCLK Fall Time                     |               | 20                                          |          | 10     |          |
| 4         | TrPC       | PCLK Rise Time                     |               | 20                                          |          | 15     |          |
| 5         | TcPC       | PCLK Cycle Time                    | 250           | 4000                                        | 165      | 2000   |          |
| 6         | TsA(WR)    | Address to WR Setup Time           | 80            | •                                           | 80       |        | 1        |
| 7         | ThA(WR)    | Address to WR Hold Time            | 0             |                                             | 0        | 1.0    | 1        |
| 8         | TsA(BD)    | Address to BD Setup Time           | 80            | المساعلين منشر مشاليون أنجا مشاورة منهم     | 80       |        | 1        |
| ă         | ThA(BD)    | Address to BD Hold Time            | 0             |                                             | 0        |        | 1        |
| 10        | TsIA/PC)   | INTACK to PCI K Setup Time         | 0             |                                             | 0        |        | 1        |
| 11        | TelAi/W/R) | INTACK to WB Setup Time            | 200           |                                             | 160      | 1      | 2        |
| 12        |            | INTACK to WB Hold Time             |               |                                             | 1 100    | +      | 1        |
| 12        |            | INTACK to PD Sotup Time            | 200           |                                             | 160      | +      | 2        |
| 10        |            | INTACK to PD Hold Time             | -200          |                                             | 100      | +      |          |
| 14        |            |                                    | 100           |                                             | 100      |        |          |
| 15        |            |                                    | 100           |                                             | 100      | +      | +        |
| 16        | THOR (MP)  | CE LOW to WR Setup Time            |               |                                             |          |        |          |
| 1/        |            | CE to WR Hold Time                 | 0             | ليحتصب فالبديات البديات المستحصيا المتقالات |          |        | <u> </u> |
| 18        | IsCEh(WR)  | CE HIGH to WR Setup Time           | 100           |                                             | /0       |        | 2        |
| <u>19</u> | IsCE1(RD)  | CE LOW to RD Setup Time            | 0             |                                             | 0        |        | 2        |
| <u>20</u> | ThCE(RD)   | CE to RD Hold Time                 | 0             |                                             | 0        |        | 2        |
| 21        | TsCEh(RD)  | CE HIGH to RD Setup Time           | 100           |                                             | 70       |        | 2        |
| 22        | TwRD1      | RD LOW Width                       | 390           |                                             | 250      |        |          |
| 23        | TdRD(DRA)  | RD to Read Data Active Delay       | 0             | · · · · · · · · · · · · · · · · · · ·       | 0        |        |          |
| <u>24</u> | TdRDr(DR)  | RD to Read Data Not Valid Delay    | 0             |                                             | 0        | 1      |          |
| 25        | TdRDf(DR)  | RD to Read Data Valid Delay        |               | 250                                         |          | 180    |          |
| 26        | TdRD(DRz)  | RD to Read Data Float Delay        |               | 70                                          |          | 45     | 3        |
| 27        | TdA(DR)    | Address Required Valid to          |               | 590                                         |          | 420    |          |
| 20        | TWAD       |                                    |               |                                             | 050      |        | -        |
| 20        |            | Write Dete to WD Setue Time        | -390          |                                             | 230      |        |          |
| 29        |            | White Data to WA Setup Time        | <u> </u>      |                                             | <u>-</u> |        |          |
| 30        |            | Write Data to WR Hold Time         | 0             | 0.40                                        | 0        |        |          |
| 31        |            | WR to wait valid Delay             |               | 240                                         |          | 200    |          |
| 32        |            | RD to Wait Valid Delay             |               | 240                                         |          | 200    | 5        |
| 33        | IdWRf(REQ) | WR to W/REQ Not Valid Delay        |               | 240                                         |          | 200    |          |
| 34        | IdRDf(REQ) | RD to W/REQ Not Valid Delay        |               | 240                                         | · ·      | 200    |          |
| 35        | TdWRr(REQ) | WR to DTR/REQ Not Valid Delay      |               | (5TcPC                                      |          | (5TcPC |          |
|           |            |                                    |               | +300)                                       |          | +250)  |          |
| 36        | TdRDr(REQ) | RD to DTR/REQ Not Valid Delay      |               | (5TcPC                                      |          | (5TcPC |          |
|           |            |                                    |               | +300)                                       |          | +250)  | · · · ·  |
| 37        | TdPC(INT)  | PCLK to INT Valid Delay            |               | 500                                         |          | 500    | 5        |
| <u>38</u> | TdIAi(RD)  | INTACK to RD (Acknowledge) Delay   | 250           |                                             | 250      |        | 6        |
| 39        | TwRDA      | RD (Acknowledge) Width             | 285           |                                             | 250      |        |          |
| 40        | TdRDA(DR)  | RD (Ack.) to Read Data Valid Delay |               | 190                                         |          | 180    |          |
| 41        | TsIEI(RDA) | IEI to RD (Acknowledge) Setup Time | 120           |                                             | 100      |        | 1        |
| 42        | ThIEI(RDA) | IEI to RD (Acknowledge) Hold Time  | 0             |                                             | 0        |        |          |
| 43        | TdIEI(IEO) | IEI to IEO Delay Time              |               | 120                                         | 1        | 100    | 1        |
| 44        | TdPC(IEO)  | PCLK to IEO Delay                  |               | 250                                         |          | 250    |          |
| 45        | TdBDA(INT) | BD to INT Inactive Delay           |               | 500                                         |          | 500    | 5        |
| 46        | TdBD/WBO)  | BD to WB Delay for No Beset        | 30            |                                             | 15       | 1      | +        |
| 47        | TdWBO/BD)  | WB to BD Delay for No Poset        | 30            |                                             | 1 20     |        | -        |
| 49        | TWRES      | WR and RD Coincident Low for Deast | 250           |                                             | 250      | -      | +        |
| 40        | Tre        | Valid Access Recovery Time         | 250<br>(6ToPC |                                             | (6TcPC   |        |          |
| -+3       |            | Valu Access necovery Time          | +200)         |                                             | +130)    |        | 1        |



# **READ AND WRITE TIMING (NOTES)**

- 1. Units are in nanoseconds.
- 2. Parameter does not apply to Interrupt Acknowledge transactions.
- 3. Float delay is defined as the time required for a  $\pm$ 0.5 V change at the output with a maximum dc load and minimum ac load.
- 4. Parameter applies only between transactions involving the SCC.
- 5. Open-drain output, measured with open-drain test load.
- 6. Parameter is system dependent. For any SCC in the daisy chain,

TdIAi(RD) must be greater than the sum of TdPC(IEO) for the highest priority device in the daisy chain, TsIEI(RDA) for the SCC, and TdIEIf(IEO) for each device separating them in the daisy chain.






### FIGURE 37. GENERAL TIMING (SEE TABLE 2)





### TABLE 2. GENERAL TIMING

| No. | Symbol      | Parameter 4 MHz                                |               |       | 6             | Γ     |       |
|-----|-------------|------------------------------------------------|---------------|-------|---------------|-------|-------|
|     | -           |                                                | Min*          | Max*  | Min*          | Max*  | Notes |
| 1   | TdPC(REQ)   | PCLK to W/REQ Valid Delay                      |               | 250   |               | 250   |       |
| 2   | TdPC(W)     | PCLK to Wait Inactive Delay                    |               | 350   |               | 350   |       |
| 3   | Ts RXC(PC)  | RxC to PCLK Setup Time<br>(PCLK + 4 Case Only) | 80            | TwPC1 | 70            | TwPC1 | 2,5   |
| 4   | TsRXD(RXCr) | RxD to RxC Setup Time (X1 Mode)                | 0             |       | 0             |       | 2     |
| 5   | ThRXD(RXCr) | RxD to RxC Hold Time (X1 Mode)                 | 150           |       | 150           | T     | 2     |
| 6   | TsRXD(RXCf) | RxD to RxC Setup Time (X1 Mode)                | 0             |       | 0             |       | 2,6   |
| 7   | ThRXD(RXCf) | RxD to RxC Hold Time (X1 Mode)                 | 150           |       | 150           |       | 2,6   |
| 8   | TsSY(RXC)   | SYNC to RxC Setup Time                         | -200          |       | -200          |       | 4,2   |
| 9   | ThSY(RXC)   | SYNC to RxC Hold Time                          | 3TcPC<br>+200 |       | 3TcPC<br>+200 |       | 4.2   |
| 10  | TsTXC(PC)   | TxC to PCLK Setup Time                         | 0             |       | 0             |       | 3.5   |
| 11  | TdTXCf(TXD) | TxC to TxD Delay (X1 Mode)                     |               | 300   |               | 230   | 3     |
| 12  | TdTXCr(TXD) | TxC to TxD Delay (X1 Mode)                     |               | 300   |               | 230   | 3.5   |
| 13  | TdTXD(TRX)  | TxD to TRxC Delay (Send Clock Echo)            |               | 200   |               | 200   |       |
| 14  | TwRTXh      | RTxC HIGH Width                                | 180           |       | 180           |       | 7     |
| 15  | TwRTXI      | RTxC LOW Width                                 | 180           |       | 180           |       | 7     |
| 16  | TcRTX       | RTxC Cycle Time                                | 400           |       | 400           | 1     | 7     |
| 17  | TcRTXX      | Crystal Oscillator Period                      | 250           | 1000  | 250           | 1000  | 3     |
| 18  | TwTRXh      | TRXC HIGH Width                                | 180           |       | 180           |       | 4,7   |
| 19  | TwTRXI      | TRxC LOW Width                                 | 180           |       | 180           |       | 4,7   |
| 20  | TcTRX       | TRxC Cycle Time                                | 400           |       | 400           |       | 4,7   |
| 21  | TwEXT       | DCD or CTS Pulse Width                         | 200           |       | 200           |       | 1     |
| 22  | TwSY        | SYNC Pulse Width                               | 200           |       | 200           |       |       |

### TABLE 3. SYSTEM TIMING

| No. | Symbol     | Parameter                                | 4 MHz |      | 6    |      |       |
|-----|------------|------------------------------------------|-------|------|------|------|-------|
|     |            |                                          | Min*  | Max* | Min* | Max* | Notes |
| 1   | TdRXC(REQ) | RxC to W/REQ Valid Delay                 | 8     | 12   | 8    | 12   | 2     |
| 2   | TdRXC(W)   | RxC to Wait Inactive Delay               | 8     | 12   | 8    | 12   | 1,2   |
| 3   | TdRXC(SY)  | RxC to SYNC Valid Delay                  | 4     | 7    | 4    | 7    | 2     |
| 4   | TdRXC(INT) | RxC to INT Valid Delay                   | 10    | 16   | 10   | 16   | 1,2   |
| 5   | TdTXC(REQ) | TxC to W/REQ Valid Delay                 | 5     | 8    | 5    | 8    | 3     |
| 6   | TdTXC(W)   | TxC to Wait Inactive Delay               | 5     | 8    | 5    | 8    | 1,3   |
| 7   | TdTXC(DRQ) | TxC to DTR/REQ Valid Delay               | 4     | 7    | 4    | 7    | 3     |
| 8   | TdTXC(INT) | TxC to INT Valid Delay                   | 6     | 10   | 6    | 10   | 1,3   |
| 9   | TdSY(INT)  | SYNC Transition to INT Valid Delay       | 2     | 6    | 2    | 6    | 1     |
| 10  | TdEXT(INT) | DCD or CTS Transition to INT Valid Delay | 2     | 6    | 2    | 6    | 1     |

- General and System Timing Notes:
- 1. Open-drain output, measured with open-drain test load.
- 2. RxC is RTxC or TRxC, whichever is supplying the transmit clock.
- 3. TxC is TRxC or RTxC, whichever is supplying the transmit clock.
- 4. Both TrxC and SYNC have 30 pF capacitors to ground connected to them.
- 5. Parameter applies only if the data rate is one-fourth the PCLK rate. In all other cases, no phase relationship between RxC and PCLK or TxC and PCLK is required.
- 6. Parameter applies only to FM encoding/decoding.
- 7. Parameter applies only for transmitter and receiver; DPLL and baud rate generator timing requirements are identical to chip PCLK requirements.
- \* Units are in nanoseconds (ns).



### FIGURE 38. SYSTEM TIMING (SEE TABLE 3)





### **ABSOLUTE MAXIMUM RATINGS**

| Voltages on all pins<br>with respect to GND | -0.3V to + 7.0V |
|---------------------------------------------|-----------------|
| Operating Ambient<br>Temperature            | 0°C to 70°C     |

Storage Temperature -65°C to + 150°C

### STANDARD TEST CONDITIONS

The dc characteristics and capacitance section below apply for the following standard test conditions, unless otherwise noted. All voltages are referenced to GND. Positive current flows into the referenced pin.

Standard conditions are as follows:

- $+4.75 \text{ V} \le \text{Vcc} \le +5.25 \text{ V}$
- GND = O V
- TA as specified in Ordering Information



+5¥

those listed on the operational sections of this specification is not implied and exposure to absolute maximum ratings conditions for extended periods may affect device reliability.



### **DC CHARACTERISTICS:** VCC = 5 V $\pm$ 5%, TA = 0°C to 70°C

| Symbol | Parameter          | Min  | Max       | Unit | Conditions                                           |
|--------|--------------------|------|-----------|------|------------------------------------------------------|
| VIH    | Input High Voltage | 2.0  | VCC + 0.3 | V    |                                                      |
| VIL    | Input Low Voltage  | -0.3 | 0.8       | V    | ······································               |
| VOH    | Ouput High Voltage | 2.4  |           | V    | I <sub>OH</sub> = -250 μA                            |
| VOL    | Output Low Voltage |      | 0.4       | V    | I <sub>OH</sub> = +2.0 mA                            |
| IIL    | Input Leakage      |      | ±10.0     | μA   | $0.4 \text{ V} \le \text{V}_{IN} \le +2.4 \text{ V}$ |
| IOL    | Output Leakage     |      | ±10.0     | μA   |                                                      |
| ICC    | VCC Supply Current |      | 250       | mA   |                                                      |

### CAPACITANCE: TA = 0°C to 70°C, f = 1 MHz

| Symbol | Parameter                 | Min | Max | Unit | Conditions |
|--------|---------------------------|-----|-----|------|------------|
| CIN    | Input Capacitance         |     | 10  | pF   |            |
| COU    | Output Capacitance        |     | 15  | рF   |            |
| CI/O   | Bidirectional Capacitance |     | 20  | pF   |            |

# VL85C35



## ENHANCED SERIAL COMMUNICATIONS CONTROLLER (ESCC) FEATURES DESCRIPTION

- Enhanced SCC functions support DMA:
  - 14-bit byte counter
  - 19- bit-wide FIFO
- Completely downward-compatible with the NMOS 8530
- Two independent full-duplex channels
- Programmable clock factor
- · Break generation and error detect
- Intelligent SDLC/HDLC

**PIN DIAGRAM** 

- Local loopback and auto echo modes
- Internal or external character synchronization
- Low power consuming CMOS

#### The VL85C35 CMOS Enhanced Serial Communications Controller (ESCC) is a dual-channel, multi-protocol data communications peripheral designed for use with non-multiplexed buses. The ESCC can be software-configured to satisfy a wide variety of serial communications applications. The device contains a variety of new. sophisticated internal functions, including all of the features of the NMOS 8530. In addition, the VI 85C35 Enhanced SCC contains a 10 X 19-bit FIFO array and 14-bit byte counter. These features, in addition to the new higher clock frequency capabilities. allow the ESSC to be used with a direct memory access (DMA) controller.

The ESCC handles asynchronous formats, such synchronous byte-oriented protocols as IBM Bisync and synchronous bit-oriented protocols as HDLC and IBM SDLC. This versatile device supports virtually any serial data transfer application (cassette, diskette, tape drives, etc.), including DMA.

The device can generate and check CRC codes in any synchronous mode and can be programmed to check data integrity in various modes. The ESCC also has facilities for modem controls in both channels, in addition to its Byte-Counting Register, and FIFO in SDLC mode.

### BLOCK DIAGRAM





### **ORDER INFORMATION**

| Part<br>Number | Clock<br>Frequency | Package                     |
|----------------|--------------------|-----------------------------|
| VL85C35-04PC   |                    | Plastic DIP                 |
| VL85C35-04QC   | 4 MHz              | Plastic Leaded Chip Carrier |
| VL85C35-04CC   |                    | Ceramic DIP                 |
| VL85C35-06PC   |                    | Plastic DIP                 |
| VL85C35-06QC   | 6 MHz              | Plastic Leaded Chip Carrier |
| VL85C35-06CC   |                    | Ceramic DIP                 |
| VL85C35-10PC   |                    | Plastic DIP                 |
| VL85C35-10QC   | 10 MHz             | Plastic Leaded Chip Carrier |
| VL85C35-10CC   |                    | Ceramic DIP                 |

Note: Operating temperature range: 0°C to +70°C.







### SIGNAL DESCRIPTIONS

| Signal<br>Name       | DIP Pin<br>Number       | Signal<br>Description                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A/B                  | 34                      | Channel A/Channel B Select input - This signal selects the channel on which the read or write operation occurs.                                                                                                                                                                                                                                                                                                       |
| C/E                  | 33                      | Chip Enable Active-LOW input - Selects the ESCC for a read or write operation.                                                                                                                                                                                                                                                                                                                                        |
| CTSA,<br>CTSB        | 18<br>22                | Clear To Send Active-LOW inputs - If these pins are programmed as auto enables, a LOW<br>on the inputs enables the respective transmitters. If not programmed as auto enables,<br>they may be used as general-purpose inputs. Both inputs are Schmitt-trigger buffered to<br>accommodate slow rise-time inputs. The ESCC detects pulses on these inputs and can<br>interrupt the CPU on both logic level transitions. |
| D/C                  | 32                      | Data/Control Select input - This signal defines the type of information transferred to or<br>from the ESCC. A HIGH means data is transferred; a LOW indicates a command.                                                                                                                                                                                                                                              |
| DCDA,<br>DCDB        | 19<br>21                | Data Carrier Detect Active-LOW inputs - These pins function as receiver enables if they<br>are programmed for auto enables; otherwise, they may be used as general-purpose input<br>pins. Both pins are Schmitt-trigger buffered to accomodate slow rise-time signals. The<br>ESCC detects pulses on these pins and can interrupt the CPU on both logic level<br>transitions.                                         |
| D0-D7                | 40,1,39,2,38,<br>3,37,4 | Data Bus, bidirectional three-state - These lines carry data and commands to and from the ESCC.                                                                                                                                                                                                                                                                                                                       |
| DTR/REQA<br>DTR/REQB | 16,<br>24               | Data Terminal Ready/Request Active-LOW outputs - These outputs follow the state pro-<br>grammed into the DTR bit. They can also be used as general-purpose outputs or as<br>request lines for a DMA controller.                                                                                                                                                                                                       |
| IEI                  | 7                       | Interrupt Enable In Active-HIGH input - IEI is used with IEO to form an interrupt daisy<br>chain when there is more than one interrupt-driven device. A HIGH IEI indicates that no<br>other higher priority device has an interrupt under service or is requesting an interrupt.                                                                                                                                      |
| IEO                  | 6                       | Interrupt Enable Out Active-HIGH output - IEO is HIGH only if IEI is HIGH and the CPU is<br>not servicing an ESCC interrupt or the ESCC is not requesting an interrupt (Interrupt<br>Acknowledge cycle only). IEO is connected to the next lower priority device's IEI input,<br>and thus inhibits interrupts from lower priority devices.                                                                            |



### SIGNAL DESCRIPTIONS

| Signal<br>Name       | DIP Pin<br>Number | Signal<br>Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INT                  | 5                 | Interrupt Request Active-LOW open-drain ouput- This signal is activated when the ESCC requests an interrupt.                                                                                                                                                                                                                                                                                                                                                                                             |
| INTACK               | 8                 | Interrupt Acknowledge Active-LOW input - This signal indicates an active Interrupt<br>Acknowledge cycle. During this cycle, the ESCC interrupt daisy-chain settles. When RD<br>becomes active, the ESCC places an interrupt vector on the data bus (if IEI is High).<br>INTACK is latched by the rising edge of PCLK.                                                                                                                                                                                    |
| PCLK                 | 20                | Clock input - This is the master ESCC clock used to synchronize internal signals. PCLK is a TTL-level signal.                                                                                                                                                                                                                                                                                                                                                                                            |
| RD                   | 36                | Read Active-LOW input - This signal indicates a read operation and, when the ESCC is<br>selected, enables the ESCC's bus drivers. During the Interrupt Acknowledge cycle, this<br>signal gates the interrupt vector onto the bus if the SCC is the highest priority device<br>requesting an interrupt.                                                                                                                                                                                                   |
| RxDA,<br>RxDB        | 13,<br>27         | Receive Data Active-HIGH inputs - These input signals receive serial data at standard TTL levels.                                                                                                                                                                                                                                                                                                                                                                                                        |
| RTxCA,<br>RTxCB      | 12,<br>28         | Receive/Transmit Clocks Active-LOW inputs- <u>These</u> pins can be programmed in several different modes of operation. In each channel, <u>RTxC</u> may supply the receive clock, the transmit clock, the clock for the baud rate generator, or the clock for the Digital <u>Phase</u> -Locked Loop. These pins can also be programmed for use with the respective SYNC pins as a crystal oscillator. The receive clock may be 1, 16, 32, or 64 times the data rate in asynchronous modes.              |
| <u>RTSA,</u><br>RTSB | 17,<br>23         | Request To Send Active-LOW outputs - When the RTS bit in Write Register 5 (Figure 19) is<br>set, the RTS signal goes LOW. When the RTS bit is reset in the asynchronous mode and<br>Auto Enable is on, the signal goes HIGH after the transmitter is empty. In Synchronous<br>mode or in Asynchronous mode with Auto Enable off, the RTS pin strictly follows the state<br>of the RTS bit. Both pins can be used as general-purpose outputs.                                                             |
| SYNCA,<br>SYNCB      | 11,<br>29         | Synchronization Active-LOW inputs or outputs - These pins can act either as inputs or<br>outputs, or as part of the crystal oscillator circuit. In the Asynchronous Receive mode<br>(crystal oscillator option not selected), these pins are inputs similar to CTS and DCD. In<br>this mode, transitions on these lines affect the state of the Synchronous/Hunt status bits<br>in Read Register 0 (Figure 6) but have no other function.                                                                |
|                      |                   | In External Synchronization mode with the crystal oscillator not selected, these lines also<br>act as inputs. In this mode, SYNC must be driven LOW to receive clock cycles after the<br>last bit in the synchronous character is received. Character assembly begins on the<br>rising edge of the receive clock immediately preceding the activation of SYNC.                                                                                                                                           |
|                      |                   | In the Internal Synchronization mode (Monosync and Bisync) with the crystal oscillator<br>not selected, these pins act as outputs and are active only during the part of the receive<br>clock cycle in which synchronous characters are recognized. The synchronous condi-<br>tion is not latched, so these outputs are active each time a synchronization pattern is<br>recognized (regardless of character boundaries). In SDLC mode, these pins act as<br>outputs and are valid on receipt of a flag. |
| TxDA,<br>TxDB        | 15,<br>25         | Transmit Data Active-HIGH outputs - These output signals transmit serial data at standard<br>TTL levels.                                                                                                                                                                                                                                                                                                                                                                                                 |
| TRxCA,<br>TRxCB      | 14,<br>26         | Transmit/Receive Clocks Active-LOW inputs <u>or outp</u> uts - These pins can be programmed<br>in several different modes of operation. The TRXC may supply the receive clock or the<br>transmit clock in the input mode or supply the output of the Digital Phase-Locked Loop,<br>the crystal oscillator, the baud rate generator, or the transmit clock in the output mode.                                                                                                                            |
| WR                   | 35                | Write Active-LOW input) - When the ESCC is selected, this signal indicates a write operation. The coincidence of RD and WR is interpreted as a reset.                                                                                                                                                                                                                                                                                                                                                    |
| W/REQA,<br>W/REQB    | 10,<br>30         | Wait/Request outputs: open-drain when programmed for a wait function, driven HIGH or<br>LOW when programmed for a request function - These dual-purpose outputs may be<br>programmed as request lines for a DMA controller or as wait lines to synchronize the CPU<br>to the ESCC data rate. The reset state is wait.                                                                                                                                                                                    |



# FUNCTIONAL DESCRIPTION

The functional capabilities of the ESCC can be described from two different points of view. As a data communications device, it transmits and receives data in a wide variety of data communications protocols. As a microprocessor peripheral, the ESCC

FIGURE 1. SCC PROTOCOLS

offers such valuable features as vectored interrupts, polling, and simple handshake capability.

### DATA COMMUNICATIONS CAPABILITY

The ESCC provides two independent fullduplex channels programmable for use in any common asynchronous or synchronous data communication protocol. Figure 1 and the following description briefly detail these protocols.

Asynchronous Modes - Transmission and reception can be accomplished independently on each channel with 5 to 8 bits per character, plus optional





even or odd parity. The transmitters can supply one, 1, 1 1/2, or 2 stop bits per character and can provide a break output at any time. The receiver breakdetection logic interrupts the CPU both at the start and at the end of a received break. Reception is protected from spikes by a transient spike-rejection mechanism that checks the signal one-half a bit time after a LOW level is detected on the receive data input (RxDA or RxDB). If the LOW does not persist (as in the case of a transient), the character assembly process does not start.

Framing errors and overrun errors are detected and buffered together with the partial character on which they occur. Vectored interrupts allow fast servicing or error conditions using dedicated routines. Furthermore, a built-in checking process avoids the interpretation of a framing error as a new start bit: a framing error results in the addition of one-half a bit time to the point at which the search for the next start bit begins.

The ESCC does not require symmetric transmit and receive clock signals a feature allowing use of the wide variety of clock sources. The transmitter and receiver can handle data at a rate of 1, 1/16, 1/32, or 1/64 of the clock rate supplied to the receive and transmit clock inputs. In asynchronous modes, the SYNC pin may be programmed as an input used for such functions as monitoring a ring indicator.

Synchronous Modes. The ESCC supports both byte-oriented and bitoriented synchronous communication. Synchronous byte-oriented protocols can be handled in several modes, allowing character synchronization with a 6-bit or 8-bit synchronous character (Monosync), any 12-bit synchronization pattern (Bisync), or with an external synchronous signal. Leading sync characters can be removed without interrupting the CPU. Any 5- or 7-bit synchronous characters are detected with 8- or 16bit patterns in the ESCC by overlapping the larger pattern across multple incoming syn-chronous characters.

The CRC checking for synchronous byte-oriented modes is delayed by one character time, so that the CPU may disable CRC checking on specific characters. This permits the implementation of such protocols as IBM Bisync.

Both CRC-16 (X<sup>16</sup> + X<sup>15</sup> + X<sup>2</sup> + 1) and CCITT (X<sup>16</sup> + X<sup>12</sup> + X<sup>5</sup> + 1) error checking polynomials are supported. Either polynomial may be selected in all Synchronous modes. Users may preset the CRC generator and checker to all ones or all zeros. The SCC also pro-vides a feature that automatically transmits CRC data when no other data is available for transmission. This allows for high-speed transmissions under DMA control, with no need for CPU intervention at the end of a message. When there is no data or CRC to send in synchronous modes, the transmitter inserts 6-, 8-, or 16-bit synchronous characters, regardless of the programmed character length.

The ESCC supports synchronous bitoriented protocols, such as SDLC and HDLC, by performing automatic flag sending, zero insertion, and CRC generation. A special command can be used to abort a frame in transmission. At the end of a message, the ESCC automatically transmits the CRC and trailing flag when the transmitter underruns. The transmitter may also be programmed to send an idle line consisting of continuous flag characters or a steady marking condition.

If a transmit underrun occurs in the middle of a message, an external/status interrupt warns the CPU of this status change so that an abort may be issued. The ESCC may also be programmed to send an abort itself in case of an underrun, relieving the CPU of this task. One to eight bits per character can be sent, allowing reception of a message with no prior information about the character structure in the information field of a frame. The receiver automatically acquires synchronization on the leading flag of a frame in SDLC or HDLC and provides a synchronization signal on the SYNC pin (an interrupt can also be programmed). The receiver can be programmed to search for frames addressed by a single byte (or four bits within a byte) of a user-selected address or to a global broadcast address. In this mode, frames not matching either the user-selected or broadcast address are ignored. The number of address bytes can be extended under software control. For receiving data, an interrupt on the first received character, or an interrupt on every character, or on special condition only (end-of-frame) can be selected. The receiver automatically deletes all zeros inserted by the transmitter during character assembly. The CRC is also calculated and is automatically checked to validate frame transmission. At the end of transmission, the status of a received frame is availabe in the status registers. In SDLC mode, the ESCC must be programmed to use the SDLC CRC polynomial, but the generator and checker may be preset to all ones or all zeros.

The CRC is inverted before transmission and the receiver checks against the bit pattern 0001110100001111.

The NRZ, NRZI or FM coding may be used in any 1x mode. The parity options available in asynchronous modes are available in synchronous modes.

The ESCC can be conveniently used under DMA control to provide highspeed reception or transmission. In reception, for example, the ESCC can interrupt the CPU when the first character of a message is received. The CPU then enables the DMA to transfer the message to memory. The ESCC then issues an end-of-frame interrupt and the CPU can check the status of the received message.



Thus, the CPU is freed for other service while the message is being received. The CPU may also enable the DMA first and have the ESCC interrupt only on end-of-frame. This procedure allows all data to be transferred via the DMA.

### SDLC LOOP MODE

The ESCC supports SDLC loop mode in addition to normal SDLC. In an SDLC loop, there is a primary controller station that manages the message traffic flow on the loop and any number of secondary stations. In SDLC loop mode, the ESCC performs the functions of a secondary station while an ESCC operating in regular SDLC mode can act as a controller (Figure 3).

A secondary station in an SDLC Loop is always listening to the messages being sent around the loop, and in fact must pass these messages to the rest of the loop by retransmitting them with a one-bit time delay. The secondary station can place its own message on the loop only at specific times. The controller signals that secondary stations may transmit messages by sending a special character, called an End Of Poll (EOP), around the loop. The EOP character is the bit pattern 11111110. Because of zero insertion during messages, this bit pattern is unique and easily recognized.

When a secondary station has a message to transmit and recognizes an EOP on the line, it changes the last binary 1 of the EOP to a 0 before transmission. This has the effect of turning the EOP into a flag sequence. The secondary station now places its message on the loop and terminates the message with an EOP. Any secondary stations, further down the loop with messages to transmit, can then append their messages to the message of the first secondary station without messages to send. The following stations merely echo the incoming messages and are prohibited from placing messages on the loop (except upon recognizing an EOP). The SDLC loop mode is a programmable option in the ESCC; NRZ, NRZI, and FM coding may all be used in SDLC Loop mode.

### BAUD RATE GENERATOR

Each channel in the ESCC contains a programmable baud rate generator. Each generator consists of two 8-bit time constant registers that form a 16-bit time-constant, a 16-bit down counter, and a flip-flop on the output producing a square wave. On startup, the flip-flop on the output is set in a HIGH state, the value in the time-constant register is loaded into the counter, and the counter starts counting down. The output of the baud rate generator toggles upon reaching 0, the value in the time-constant register is loaded into the sounter starts counting down.

process is repeated. The time constant may be changed at any time, but the new value does not take effect until the next load of the counter.

The output of the baud rate generator may be used as either the transmit clock, the receive clock, or both. It can also drive the digital phase-locked loop (see next section).

If the receive clock or transmit clock is not programmed to come from the TRxC pin, the output of the baud rate generator may be echoed out via the TRxC pin.

The following formula relates the time constant to the baud rate (the baud rate is in bits/second and BR clock period is in seconds):

baud rate =

2 (time constant+2) x (BR clock period)

# DIGITAL PHASE-LOCKED

The ESCC contains a digital phaselocked-loop (DPLL) to recover clock information from a data stream with NRZI or FM encoding. The DPLL is driven by a clock that is nominally 32 (NRZI) or 16 (FM) times the data rate. The DPLL uses this clock, along with the data stream, to construct a clock for the data. This clock may then be used as the ESCC receive clock, the transmit clock, or both.

### FIGURE 3. AN SDLC LOOP



FIGURE 2. DETECTING 5- OR 7-BIT SYNCHRONOUS CHARACTERS





For NRZI encoding, the DPLL counts the 32x clock to create nominal bit times. As the 32x clock is counted, the DPLL is searching the incoming data stream for edges (either 1 to 0 or 0 to 1). Whenever an edge is detected, the DPLL makes a count adjustment (during the next counting cycle), producing a terminal count closer to the center of the bit cell.

For FM encoding, the DPLL still counts from 0 to 31, but with a cycle corresponding to two bit times. When the DPLL is locked, the clock edges in the data stream should occur between counts 15 and 16, and between counts 31 and 0. The DPLL looks for edges only during a time centered on the 15 to 16 counting transition.

The 32x clock for the DPLL can be programmed to come from either the RTxC input or the output of the baud rate generator. The DPLL output may be programmed to be echoed out of the ESCC via the TRxC pin (if this pin is not being used as an input).

#### DATA ENCODING

The ESCC may be programmed to encode and decode the serial data in four different ways (Figure 4). In NRZ encoding, a 1 is represented by a HIGH level and a 0 is represented by a LOW level. In NRZI encoding, a 1 is represented by no change in level and a 0 is represented by a change in level.

In FM1 (more properly, bi-phase mark), a transition occurs at the beginning of every bit cell. A 1 is represented by

an additional transition at the center of the bit cell and a 0 is represented by no additional transition at the center of the bit cell. In FMØ (biphase space), a transition occurs at the beginning of every bit cell. A 0 is represented by an additional transition at the center of the bit cell, and a 1 is represented by no additional transition at the center of the bit cell.

In addition to these four methods, the ESCC can be used to decode Manchester (bi-phase level) data by using the DPLL in the FM mode and programming the receiver for NRZ data. Manchester encoding always produces a transition at the center of the bit cell. If the transition is 0 to 1, the bit is a 0. If the transition is 1 to 0, the bit is a 1.

#### AUTO ECHO AND LOCAL LOOPBACK

The ESCC is capable of automatically echoing everything it receives. This feature is useful mainly in Asynchronous modes, but works in Synchronous and SDLC modes as well. In Auto Echo mode, TxD is RxD, Auto Echo mode can be used with NRZI or FM encoding with no additional delay, because the data stream is not decoded before retransmission. In Auto Echo mode, the CTS input is ignored as a transmitter enable (although transitions on this input can still cause interrupts if programmed to do so). In this mode, the transmitter is actually bypassed and the programmer is responsible for disabling

transmitter interrupts and Wait/Request on transmit.

The ESCC is also capable of local loopback. In this mode TxD is RxD, just as in auto echo mode. However, in local loopback mode, the internal transmit data is tied to the internal receive data and RxD is ignored (exc<u>ept to be echo</u>ed out via TxD). The CTS and DCD inputs are also ignored as transmit and receive enables. However, transitions on these inputs can still cause interrupts. Local loopback works in asynchronous, synchronous, and SDLC modes with NRZ, NRZI, or FM coding of the data stream.

**I/O INTERFACE CAPABILITIES** 

The ESCC offers the choice of polling, interrupt (vectored or nonvectored), and block transfer modes to transfer data, status, and control information to and from the CPU. The block transfer mode can be implemented under CPU or DMA control.

#### POLLING

All interrupts are disabled. Three status registers in the ESCC are automatically updated whenever any function is performed . For example, end-of-frame in SDLC mode sets a bit in one of these status registers. The idea behind polling is for the CPU to periodically read a status register until the register contents indicate the need for data to be transferred. Only one register needs to be read; depending on its contents, the CPU either writes data, reads data, or continues. Two bits in the register indicate the need for data transfer.



### FIGURE 4. DATA ENCODING METHODS



An alternative is a poll of the Interrupt Pending register to determine the source of an interrupt. The status for both channels resides in one register.

### INTERRUPTS

When an ESCC responds to an Interrupt Acknowledge signal (INTACK) from the CPU, an interrupt vector may be placed on the data bus. This vector is written in Write Register 2 (WR2) and may be read in Read Register 2A (RR2A) or Read Register 2B (RR2B) (Figures 8).

To speed interrupt response time, the ESCC can modify three bits in this vector to indicate status. If the vector is read in Channel A, status is never included; if it is read in Channel B, status is always included.

Each of the six sources of interrupts in the ESCC (Transmit, Receive, and External/Status interrupts in both channels) has three bits associated with the interrupt source: Interrupt Pending (IP), Interrupt Under Service (IUS), and Interrupt Enable (IE). Operation of the IE bit is straightforward. If the IE bit is set for a given interrupt source, that source can request interrupts. The exception is when the MIE (Master Interrupt Enable) bit in WR9 is reset and no interrupts may be requested. The IE bits are write only.

The other two bits are related to the interrupt priority chain (Figure 5). As a microprocessor peripheral, the ESCC may request an interrupt only when no higher priority device is requesting one; e.g., when IEI is HIGH. If the device in question requests an interrupt, it pulls

down INT. The CPU then responds with INTACK, and the interrupting device places the vector on the data bus.

In the ESCC, the IP bit signals a need for interrupt servicing. When an IP bit is 1 and the IEI input is HIGHh, the INT output is pulled LOW, requesting an interrupt. In the ESCC, if the IE bit is not set by enabling interrupts, then the IP for that source can never be set. The IP bits are readable in RR3A.

The IUS bits signal that an interrupt request is being serviced. If an IUS is set, all interrupt sources of lower priority in the ESCC and external to the ESCC are prevented from requesting interrupts. The internal interrupt sources are inhibited by the state of the internal daisy chain, while lower priority devices are inhibited by the IEO output of the ESCC being pulled LOW and propagated to subsequent peripherals. An IUS bit is set during an interrupt acknowledge cycle if there are no higher priority devices requesting interrupts.

There are three types of interrupts: transmit, receive, and external/status. Each interrupt type is enabled under program control with Channel A having higher priority than Channel B, and with receive, transmit, and external/status interrupts prioritized in that order within each channel. When the transmit interrupt is enabled, the CPU is interrupted when the transmit buffer becomes empty. (This implies that the transmitter must have had a data character written into it so that it can become empty.) When enabled, the receiver can interrupt the CPU in one of three ways:

- On first receive character or special receive condition
- On all receive characters or special receive condition
- · On special receive condition only.

Interrupt on first character or special condition and interrupt on special condition only are typically used with the Block Transfer mode. A special receive condition is one of the following: receiver overrun, framing error in Asynchronous mode, end-of-frame in SDLC mode, and optionally, a parity error. The special receive condition interrupt is different from an ordinary receive character interrupt only in that the status is placed in the vector during the Interrupt Acknowledge cycle. In interrupt on first receive character, an interrupt can occur from special receive conditions any time after the first receive character interrupt.

The main function of the external/status interrupt is to monitor the signal transitions of the CTS, DCD, and SYNC pins; however, an external/status interrupt is also caused by a transmit underrun condition, or a zero count in the baud rate generator, or by the detection of a break (asynchronous mode), abort (SDLC mode) or EOP (SDLC loop mode) sequence in the data stream.

### FIGURE 5. INTERRUPT SCHEDULE



# VL85C35

The interrupt caused by the abort or EOP has a special feature allowing the ESCC to interrupt when the abort or EOP sequence is detected or terminated. This feature facilitates the proper termination of the current message, correct initialization of the next message, and the accurate timing of the Abort condition in external logic in SDLC mode.

In SDLC Loop mode, this feature allows secondary stations to recognize the

need of the primary station to regain control of the loop during a poll sequence.

CPU/DMA BLOCK TRANSFER The ESCC provides a Block Transfer mode to accommodate CPU block transfer functions and DMA controllers. The Block Transfer mode uses the Wait/Request output in conjunction with the Wait/Request bits in WR1. The Wait/Request output can be defined under software control as a Wait line in the CPU Block Transfer mode or as a Request line in the DMA Block Transfer mode.

To a DMA controller, the ESCC Request output indicates that the ESCC is ready to transfer data to or from memory. To the CPU, the Wait line indicates that the ESCC is not ready to transfer data, thereby requesting that the CPU extend the *i*/O cycie. The DTR/Request line allows full-duplex operation under DMA control.

### PROGRAMMING

The ESCC contains 13 write registers in each channel that are programmed by the system separately to configure the functional personality of the channels.

In the ESCC, register addressing is direct for the data registers only, which are selected by a HIGH on the D/C pin. In all other cases (with the exception of WR0 and RR0), programming the write registers requires two write operations and reading the read registers requires both a write and a read operation. The first write is to WR0 and contains three bits that point to the selected register. The second write is the actual control word for the selected register, and if the second operation is read, the selected read register is accessed. All of the registers in the ESCC, including the data registers, may be accessed in this fashion. The pointer bits are automatically cleared after the read or write operation so that WR0 (or RR0) is addressed again.

The system program first issues a series of commands to initialize the basic mode of operation. This is followed by other commands to qualify conditions within the selected mode. For example, the asynchronous mode, character length, clock rate, number of stop bits, and even or odd parity might be set first. Then the interrupt mode would be set, and, finally, receiver or trans-mitter enable.

### **READ REGISTERS**

The ESCC contains ten read registers (eleven counting receive buffer RR8) in each channel. Four of these may be read to obtain status information (RR0, RR1, RR10, and RR15). Two registers (RR12 and RR13) may be read to learn the baud rate generator time constant. The RR2 contains either the unmodified interrupt vector (Channel A) or the vector modified by status information (Channel B). Both RR7 and RR6 read the DMA FIFO. The RR3 contains the Interrupt Pending (IP) bits (Channel A). Figures 6 through 13 and Figure 41 show the formats for each read register.

The status bits of RR0 and RR1 are carefully grouped to simplify status monitoring; e.g., when the interrupt vector indicates a special receive condition interrupt, all the appropriate error bits can be read from a single register (RR1).

### WRITE REGISTERS

The ESCC contains 13 write registers (14 counting WR8, the transmit buffer) in each channel. These write registers are programmed separately to configure the functional personality of the channels. In addition, there are two registers (WR2 and WR9) shared by the two channels that may be accessed through either of them; WR2 contains the interrupt vector for both channels, while WR9 contains the interrupt control bits. Figures 14 through 28 and Figure 41 show the format of each write register.

### TIMING

The ESCC generates internal control signals from WR and RD that are related to PCLK. Since PCLK has no phase relationship with WR and RD, the circuitry generating these internal control signals must provide time for metastable conditions to disappear. This gives rise to a recovery time related to PCLK. The recovery time applies only between bus transactions involving the ESCC. The recovery time required for proper operation is specified from the rising edge of WR or RD in the first transaction involving the SCC, to the falling edge of WR or RD in the second transaction involving the ESCC. This

time must be at least four PCLK cycles plus 200 ns.

### READ CYCLE TIMING

Figure 29 illustrates Read cycle timing. Addresses on  $\overline{A/B}$  and  $\overline{D/C}$  and the status on INTACK must remain stable through the cycle. If  $\overline{CE}$  falls after  $\overline{RD}$ falls or if it rises before RD rises, the effective RD is shortened.

### WRITE CYCLE TIMING

Figure 30 illustrates Write cycle timing. Addresses on  $A/\overline{B}$  and D/ $\overline{C}$  and the status on INTACK must remain stable throughout the cycle. If  $\overline{CE}$  falls after WR falls, or if it rises before WR rises, the effective WR is shortened.

### INTERRUPT ACKNOWLEDGE CYCLE TIMING

Figure 31 illustrates Interrupt Acknowledge cycle timing. Between the time INTACK goes LOW and the falling edge of RD, the internal and external IEI/IEO daisy chains settle. If there is an interrupt pending in the ESCC and IEI is HIGH when RD falls, the Acknowledge cycle is intended for the ESCC. In this case, the ESCC may be programmed to respond to RD LOW by placing its interrupt vector on D0-D7 and it then internally sets the appropriate Interrupt-Under-Service latch.



FIGURE 6. READ REGISTER 0



### FIGURE 7. READ REGISTER 1



FIGURE 11. READ REGISTER 12





### FIGURE 9. READ REGISTER 3



### FIGURE 12. READ REGISTER 13



### FIGURE 13. READ REGISTER 15





#### FIGURE 14. WRITE REGISTER 0



### FIGURE 17. WRITE REGISTER 3



Rx ENABLE SYNC CHARACTER LOAD INHIBIT ADDRESS SEARCH MODE (SDLC) Rx CRC ENABLE ENTER HUNT MODE

AUTO ENABLES

#### FIGURE 18. WRITE REGISTER 4



#### FIGURE 19. WRITE REGISTER 5



### FIGURE 16. WRITE REGISTER 2

FIGURE 15. WRITE REGISTER 1

D7 D6 D5 D4 D3 D2 D1 D0

00

111

10



BX INT DISABLE

EXT INT ENABLE

Rx INT ON FIRST CHARACTER OR SPCL.CONDITION

INT ON ALL Rx CHARACTERS OR SPCL.CONDITION

PARITY IS SPECIAL CONDITION

Tx INT ENABLE

Rx INT ON SPECIAL CONDITION ONLY

WAIT/DMA REQUEST ON RECEIVE/TRANS. WAIT/DMA REQUEST FUNCTION WAIT/DMA REQUEST ENABLE



### FIGURE 20. WRITE REGISTER 6



(ADDR RANGE)

#### FIGURE 21. WRITE REGISTER 7





#### FIGURE 22. WRITE REGISTER 9



### FIGURE 23. WRITE REGISTER 10



#### FIGURE 24. WRITE REGISTER 11



### FIGURE 25. WRITE REGISTER 12



FIGURE 26. WRITE REGISTER 13



#### FIGURE 27. WRITE REGISTER 14



#### FIGURE 28. WRITE REGISTER 15





### FIGURE 29. READ CYCLE TIMING



### FIGURE 30. WRITE CYCLE TIMING



### FIGURE 31. INTERRUPT ACKNOWLEDGE CYCLE TIMING





FIGURE 33. READ AND WRITE TIMING (SEE TABLE 1)



FIGURE 34. RESET TIMING (SEE TABLE 1)



FIGURE 35. CYCLE TIMING (SEE TABLE 1)





### TABLE 1. READ AND WRITE TIMING CHARACTERISTICS: TA = 0°C TO +70°C

| No.       | Symbol     | Parameter                                          | 4 M             | Hz     | 6 M             | Hz                                    | 10  | MHz |       |
|-----------|------------|----------------------------------------------------|-----------------|--------|-----------------|---------------------------------------|-----|-----|-------|
|           |            |                                                    | Min             | Max    | Min             | Max                                   | Min | Max | Notes |
| 1         | TwPCI      | PCLK LOW Width                                     | 105             | 2000   | 70              | 1000                                  |     |     |       |
| 2         | TwPCh      | PCLK HIGH Width                                    | 105             | 2000   | 70              | 1000                                  |     |     |       |
| 3         | TfPC       | PCLK Fall Time                                     |                 | 20     |                 | 10                                    |     |     |       |
| 4         | TrPC       | PCLK Rise Time                                     |                 | 20     |                 | 15                                    |     |     |       |
| 5         | TcPC       | PCLK Cycle Time                                    | 250             | 4000   | 165             | 2000                                  |     |     |       |
| 6         | TsA(WR)    | Address to WR Setup Time                           | 80              |        | . 80            |                                       |     |     |       |
| 7         | ThA(WR)    | Address to WR Hold Time                            | 0               |        | 0               |                                       |     |     |       |
| 8         | TsA(RD)    | Address to RD Setup Time                           | 80              |        | 80              |                                       |     |     |       |
| 9         | ThA(RD)    | Address to RD Hold Time                            | 0               |        | 0               |                                       |     |     |       |
| 10        | TsIA(PC)   | INTACK to PCLK Setup Time                          | 0               |        | 0               |                                       |     |     |       |
| 11        | TslAi(WR)  | INTACK to WR Setup Time                            | 200             |        | 160             | N                                     |     |     | 2     |
| 12        | ThIA(WR)   | INTACK to WR Hold Time                             | 0               |        | 0               |                                       |     |     |       |
| <u>13</u> | TslAi(RD)  | INTACK to RD Setup Time                            | 200             |        | 160             |                                       |     |     | 2     |
| <u>14</u> | ThIA(RD)   | NTACK to RD Hold Time                              | 0               |        | 0               |                                       |     |     |       |
| 15        | ThIA(PC)   | INTACK to PCLK Hold Time                           | 100             |        | 100             |                                       |     |     |       |
| <u>16</u> | TsCE1(WR)  | CE LOW to WR Setup Time                            | 0               |        | · 0             |                                       |     |     |       |
| 17        | ThCE(WR)   | CE to WR Hold Time                                 | 0               |        | 0               |                                       |     |     |       |
| <u>18</u> | TsCEh(WR)  | CE HIGH to WR Setup Time                           | 100             |        | 70              |                                       |     |     | 2     |
| 19        | TsCE1(RD)  | CE LOW to RD Setup Time                            | 0               |        | 0               |                                       |     |     | 2     |
| <u>20</u> | ThCE(RD)   | CE to RD Hold Time                                 | 0               |        | 0               |                                       |     |     | 2     |
| <u>21</u> | TsCEh(RD)  | CE HIGH to RD Setup Time                           | 100             |        | 70              |                                       |     |     | 2     |
| 22        | TwRD1      | RD LOW Width                                       | 390             |        | 250             |                                       |     | ļ   |       |
| 23        | TdRD(DRA)  | RD to Read Data Active Delay                       | 0               |        | 0               |                                       |     |     |       |
| 24        | TdRDr(DR)  | RD to Read Data Not Valid Delay                    | 0               |        | . 0             |                                       |     |     |       |
| 25        | IdRDf(DR)  | RD to Read Data Valid Delay                        |                 | 250    |                 | 180                                   |     |     |       |
| 26        | IdRD(DRz)  | RD to Read Data Float Delay                        |                 | /0     |                 | 45                                    |     |     | 3     |
| 27        | TdA(DR)    | Address Required Valid to<br>Read Data Valid Delay |                 | 590    |                 | 420                                   |     |     |       |
| 28        | TwWR1      | WRI OW Width                                       | 390             |        | 250             |                                       |     |     |       |
| 29        | TsDW(WR)   | Write Data to WR Setup Time                        | 0               |        | 0.              |                                       |     |     |       |
| 30        | ThDW(WB)   | Write Data to WR Hold Time                         | 0               | [      | 0               |                                       |     |     |       |
| 31        | TdWR(W)    | WR to Wait Valid Delay                             |                 | 240    |                 | 200                                   |     |     | 5     |
| 32        | TdRD(W)    | RD to Wait Valid Delay                             |                 | 240    |                 | 200                                   |     |     | 5     |
| 33        | TdWRf(REQ) | WR to W/REQ Not Valid Delay                        |                 | 240    |                 | 200                                   |     |     |       |
| 34        | TdRDf(REQ) | RD to W/REQ Not Valid Delay                        |                 | 240    |                 | 200                                   |     |     |       |
| 35        | TdWRr(REQ) | WR to DTR/REQ Not Valid Delay                      |                 | (4TcPC |                 | (4TcPC                                |     |     |       |
|           | , , ,      |                                                    |                 | +300)  |                 | +250)                                 |     |     |       |
| 36        | TdRDr(REQ) | RD to DTR/REQ Not Valid Delay                      |                 | (4TcPC |                 | (4TcPC                                |     |     |       |
|           | . ,        |                                                    |                 | +300)  |                 | +250)                                 |     |     |       |
| 37        | TdPC(INT)  | PCLK to INT Valid Delav                            |                 | 500    |                 | 500                                   |     |     | 5     |
| 38        | TdlAi(RD)  | INTACK to RD (Acknowledge) Delay                   | 240             |        | 250             |                                       |     |     | 6     |
| 39        | TwRDA      | RD (Acknowledge) Width                             | 285             |        | 250             |                                       |     |     |       |
| 40        | TdRDA(DR)  | RD (Ack.) to Read Data Valid Delay                 |                 | 190    |                 | 180                                   |     |     | T     |
| <u>41</u> | TsIEI(RDA) | IEI to RD (Acknowledge) Setup Time                 | 120             |        | 100             |                                       |     |     |       |
| 42        | ThIEI(RDA) | IEI to RD (Acknowledge) Hold Time                  | 0               |        | 0               |                                       |     |     |       |
| 43        | TdIEI(IEO) | IEI to IEO Delay Time                              |                 | 120    |                 | 100                                   |     |     |       |
| 44        | TdPC(IEO)  | PCLK to IEO Delay                                  |                 | 250    |                 | 250                                   |     |     |       |
| <u>45</u> | TdRDA(INT) | RD to INT Inactive Delay                           |                 | 500    |                 | 500                                   |     |     | 4     |
| 46        | TdRD(WRQ)  | RD to WR Delay for No Reset                        | 30              |        | 15              |                                       |     |     |       |
| <u>47</u> | TdWRQ(RD)  | WR to RD Delay for No Reset                        | 30              |        | 30              | · · · · · · · · · · · · · · · · · · · |     |     | L     |
| <u>48</u> | TwRES      | WR and RD Coincident LOW for Reset                 | 250             |        | 250             |                                       |     |     |       |
| 49        | Trc        | Valid Access Recovery Time                         | (4TcPC<br>+200) |        | (4TcPC<br>+130) |                                       |     |     |       |



### **READ AND WRITE TIMING (NOTES)**

- 1. Units are in nanoseconds.
- 2. Parameter does not apply to Interrupt Acknowledge transactions.
- 3. Float delay is defined as the time required for a  $\pm$  0.5 V change at the output with a maximum dc load and minimum ac load.
- 4. Parameter applies only between transactions involving the ESCC.
- 5. Open-drain output, measured with open-drain test load.
- 6. Parameter is system-dependent. For any ESCC in the daisy chain,

TdIAi(RD) must be greater than the sum of TdPC (IEO) for the highest priority device in the daisy chain, TsIEI(RDA) for the ESCC, and TdIEIf(IEO) for each device separating them in the daisy chain.





### FIGURE 37. GENERAL TIMING (SEE TABLE 2)



6-96



### TABLE 2. GENERAL TIMING

| No. | Symbol      | Parameter                                      | 4 M   | Hz    | 6 M      | Hz    | 10 N | ЛНz      | 1     |
|-----|-------------|------------------------------------------------|-------|-------|----------|-------|------|----------|-------|
|     |             |                                                | Min*  | Max*  | Min*     | Max*  | Min* | Max*     | Notes |
| 1   | TdPC(REQ)   | PCLK to W/REQ Valid Delay                      |       | 250   |          | 250   |      |          |       |
| 2   | TdPC(W)     | PCLK to Wait Inactive Delav                    |       | 350   |          | 350   |      |          |       |
| 3   | Ts RXC(PC)  | RxC to PCLK Setup Time<br>(PCLK + 4 Case Only) | 8     | TwPC1 | 70       | TwPC1 |      |          | 2,5   |
| 4   | TsRXD(RXCr) | RxD to RxC Setup Time (X1 Mode)                | Û     |       | Û        |       |      |          | 2     |
| 5   | ThRXD(RXCr) | RxD to RxC Hold Time (X1 Mode)                 | 150   |       | 150      |       |      |          | 2     |
| 6   | TsRXD(RXCf) | RxD to RxC Setup Time (X1 Mode)                | 0     |       | 0        |       |      |          | 2,6   |
| 7   | ThRXD(RXCf) | RxD to RxC Hold Time (X1 Mode)                 | 150   |       | 150      |       |      |          | 2,6   |
| 8   | TsSY(RXC)   | SYNC to RxC Setup Time                         | -200  |       | -200     |       |      |          | 4,2   |
| 9   | ThSY(RXC)   | SYNC to RxC Hold Time                          | 3TcPC |       | 3TcPC    |       |      |          |       |
| 10  | T-TYO(DO)   |                                                | +200  |       | +200     |       |      | <u> </u> | 42    |
| 10  |             | TXC to PCLK Setup Time                         |       |       | <u> </u> | 000   |      | <u> </u> | 3,5   |
| 1   |             | Trocke Trop Delay (X1 Mode)                    |       | 300   |          | 230   |      |          |       |
| 12  |             | Truc to TXD Delay (X1 Mode)                    |       | 300   |          | 230   |      |          | 3,5   |
| 14  |             | BTyC HIGH Width                                | 180   | 200   | 180      | 200   |      |          | +     |
| 15  | TwBTXI      | BTxCI OW Width                                 | 180   |       | 180      |       |      |          | 7     |
| 16  | TcRTX       | RTxC Cycle Time                                | 400   |       | 400      |       |      | 1        | 7     |
| 17  | TcRTXX      | Crystal Oscillator Period                      | 250   | 1000  | 250      | 1000  |      |          | 3     |
| 18  | TwTBXh      | TRxC HIGH Width                                | 180   |       | 180      |       |      | 1        | 4.7   |
| 19  | TwTRXI      | TRXC LOW Width                                 | 180   | 1     | 180      |       |      |          | 4.7   |
| 20  | TcTRX       | TRxC Cycle Time                                | 400   |       | 400      |       |      |          | 4.7   |
| 21  | TwEXT       | DCD or CTS Pulse Width                         | 200   |       | 200      |       |      | 1        | 1     |
| 22  | TwSY        | SYNC Pulse Width                               | 200   |       | 200      |       |      | 1        |       |

### TABLE 3. SYSTEM TIMING

| No. | Symbol     | Parameter                                | 4 MHz |      | 6 MHz |      | 10 MHz |      |       |
|-----|------------|------------------------------------------|-------|------|-------|------|--------|------|-------|
|     |            |                                          | Min*  | Max* | Min*  | Max* | Min*   | Max* | Notes |
| 1   | TdRXC(REQ) | RxC to W/REQ Valid Delay                 | 8     | 12   | 8     | 12   |        |      | 2     |
| 2   | TdRXC(W)   | RxC to Wait Inactive Delay               | 8     | 12   | 8     | 12   |        |      | 1,2   |
| 3   | TdRXC(SY)  | RxC to SYNC Valid Delay                  | 4     | 7    | 4     | 7    |        |      | 2     |
| 4   | TdRXC(INT) | RxC to INT Valid Delay                   | 10    | 16   | 10    | 16   |        |      | 1,2   |
| 5   | TdTXC(REQ) | TxC to W/REQ Valid Delay                 | 5     | 8    | 5     | 8    |        |      | 3     |
| 6   | TdTXC(W)   | TxC to Wait Inactive Delay               | 5     | 8    | 5     | 8    |        |      | 1,3   |
| 7   | TdTXC(DRQ  | TxC to DTR/REQ Valid Delay               | 4     | 7    | 4     | 7    |        |      | 3     |
| 8   | TdTXC(INT) | TxC to INT Valid Delay                   | 6     | 10   | 6     | 10   |        |      | 1,3   |
| 9   | TdSY(INT)  | SYNC Transition to INT Valid Delay       | 2     | 6    | 2     | 6    |        |      | 1     |
| 10  | TdEXT(INT) | DCD or CTS Transition to INT Valid Delay | 2     | 6    | 2     | 6    |        |      | 1     |

General and System Timing Notes:

- 1. Open-drain output, measured with open-drain test load.
- 2. RxC is RTxC or TRxC, whichever is supplying the transmit clock.
- TxC is TRxC or RTxC, whichever is supplying the transmit clock.
- 4. Both TrxC and SYNC have 30 pF capacitors connected to ground.
- 5. Parameter applies only if the data rate is one-fourth the PCLK rate. In all other cases, no phase relationship between RxC and PCLK or TxC and PCLK is required.
- 6. Parameter applies only to FM encoding/decoding.
- 7. Parameter applies only for transmitter and receiver; DPLL and baud rate generator timing requirements are identical to chip PCLK requirements.

\* Units are in nanoseconds (ns).



### FIGURE 38. SYSTEM TIMING (SEE TABLE 3)





#### FIGURE 39. ESCC STATUS REGISTER



### **FIFO DETAIL**

For a better understanding of details of the FIFO operation, refer to the block diagram in Figure 39.

### ENABLE/DISABLE

This FIFO is implemented so that it is only enabled when Channel A register WR15 bit 2 is set and the ESCC is in the SDLC/HDLC mode, otherwise the status register contents bypass the FIFO and go directly to the bus interface (the FIFO pointer logic is reset either when disabled or via a channel or power-on reset). When the FIFO mode is disabled, the ESCC is completely downward-compatible with the HMOS VL8530. The FIFO mode is disabled on power-up (WR15 bit 2 is set to 0 on reset). The effects of backward compatibility on the register set are that RR4 is an image of RR0, RR5 is an image of RR1, RR6 is an image of RR2, and RR7 is an image of RR3. For details of the added registers, refer to Figure 3. The status of the FIFO Enable signal can be obtained by reading Channel A RR15 bit 2. If the FIFO is enabled, the bit will be set to 1; otherwise, it will be reset. Channel B WR15 and RR15 behave exactly as in the VL8530 standard product.

### **READ OPERATION**

When WR15 bit 2 is set and the FIFO is not empty, the next read to any of status register RR1 or the additional registers RR7 and RR6 will actually be from the FIFO. Reading status register RR1 causes one location of the FIFO to be émptied, so status should be read after reading the byte count, otherwise the count will be incorrect. Before the FIFO underflows, it is disabled. In this case, the multiplexer is switched to allow status to read directly from the status register, and reads from RR7 and RR6 will contain bits that are undefined. Bit 6 of RR7 (FIFO Data Available) can be used to determine if status data is coming from the FIFO or directly from the status register, since it is set to one whenever the FIFO is not empty.

Since not all status bits must be stored in the FIFO, the All Sent, Parity, and EOF bits will bypass the FIFO. The status bits sent through the FIFO will be Residue Bits (3), Overrun, and CRC Error.

The sequence for proper operation of the byte count and FIFO logic is to read the registers in the following order: RR7, RR6, and RR1 (reading RR6 is optional). Additional logic prevents the FIFO from



#### FIGURE 40. SDLC BYTE COUNTING DETAIL



being emptied by multiple reads from RR1. The read from RR7 latches the FIFO empty/full status bit (bit 6) and steers the status multiplexer to read from the ESCC megacell instead of the status FIFO (since the status FIFO is empty). The read from RR1 allows an entry to be read from the FIFO (if the FIFO was empty, logic is added to prevent a FIFO underflow condition).

#### WRITE OPERATION

When the end of an SDLC frame (EOF) has been received and the FIFO is enabled, the contents of the status and byte-count registers are loaded into the FIFO. The EOF signal is used to increment the FIFO. If the FIFO overflows, the MSB of RR7 (FIFO Overflow) is set to indicate the overflow. This bit and the FIFO control logic is reset by disabling and re-enabling the FIFO control bit (WR15 bit 2). For details of FIFO control timing during an SDLC frame, refer to Figure 40.

### BYTE COUNTER DETAIL

The 14-bit byte counter allows for packets up to 16K bytes to be received. For a better understanding of its operation, refer to Figures 39 and 40.

#### ENABLE

The byte counter is enabled in the SDLC/HDLC mode.

#### RESET

The byte counter is reset whenever an SDLC flag character is received. The reset is timed so that the contents of the byte counter are successfully written into the FIFO.

#### INCREMENT

The byte counter is incremented by writes to the data FIFO. The counter represents the number of bytes received by the ESCC, rather than the number of bytes transferred from the ESCC. (These counts may differ by up to the number of bytes in the receive data FIFO contained in the ESCC.)



### **ABSOLUTE MAXIMUM RATINGS**

| Voltages on all pins<br>with respect to GND | -0.3 V to + 7.0 V |
|---------------------------------------------|-------------------|
| Operating Ambient<br>Temperature            | 0°C to +70°C      |

Storage Temperature -65°C to + 150°C

### STANDARD TEST CONDITIONS

The dc characteristics and capacitance section below apply for the following standard test conditions, unless otherwise noted. All voltages are referenced to GND. Positive current flows into the referenced pin.

Standard conditions are as follows:

- $4.75 \text{ V} \le \text{VCC} \le 5.25 \text{ V}$
- GND = 0 V
- TA = 0°C to +70°C



### DC CHARACTERISTICS: VCC = 5 V ± 5%, TA = 0°C to 70°C

| Symbol | Parameter          | Min  | Мах       | Unit | Conditions           |  |  |
|--------|--------------------|------|-----------|------|----------------------|--|--|
| VIH    | Input HIGH Voltage | 2.0  | VCC + 0.3 | V    |                      |  |  |
| VIL    | Input LOW Voltage  | -0.3 | 0.8       | V    |                      |  |  |
| VOH    | Ouput HIGH Voltage | 2.4  |           | v    | IOH = -250 μA        |  |  |
| VOL    | Output LOW Voltage |      | 0.4       | v    | IOH = +2.0 mA        |  |  |
| IIL    | Input Leakage      |      | ±10.0     | μA   | 0.4 V ≤ VIN ≤ +2.4 V |  |  |
| IOL    | Output Leakage     |      | ±10.0     | μA   |                      |  |  |
|        | VCC Supply Current |      | 250       | mA   |                      |  |  |

Stresses above those listed under

"Absolute Maximum Ratings" may

Functional operation of this device at

these or any other conditions above

cause permanent damage to the device. These are stress ratings only.

### CAPACITANCE: VCC = 5 V ± 5%, TA = 0°C to 70°C

| Symbol | Parameter                 |  | Max | Unit | Conditions |
|--------|---------------------------|--|-----|------|------------|
| CIN    | Input Capacitance         |  | 10  | pF   |            |
| COUT   | Output Capacitance        |  | 15  | pF   |            |
| CI/O   | Bidirectional Capacitance |  | 20  | рF   |            |

f = 1 MHz over specified temperature range. Unmeasured pins returned to ground.

those listed on the operational sections of this specification is not implied and exposure to absolute maximum ratings conditions for extended periods may affect device reliability.



| SECTION 7<br>TELECOMM<br>PRODUCTS |
|-----------------------------------|
|                                   |
|                                   |
|                                   |
|                                   |
|                                   |
|                                   |
|                                   |
|                                   |
|                                   |

Application Specific Logic Products Division



## **VL7C103 300 BAUD MODEM**



### FEATURES

- Low cost single chip 300 BPS modem
- · Full answer and originate option
- · Uses switched capacitor filters
- · Implements all filters and hybrid circuits on chip
- Output level up to -9 dBm with  $600\Omega$ line impedance
- Analog loopback capability for testing
- Power down mode for low power use

- Low power consumption, single +5V CMOS design
- Bell 103 compatible
- Direct replacement for the National Semiconductor NS74HC943
- · Functional replacement for Texas Instruments TMS99532

### DESCRIPTION

The VL7C103 is a single chip, full duplex, 300 Bit Per Second (BPS) modem compatible with the Bell 103 specifications. It is intended for data communications over the general switched telephone network, and can also be used with other voice band channels.

The VL7C103 requires a single +5 volt power supply and is implemented in 3micron switched capacitor technology. This part is pin-for-pin compatible with the National Semiconductor NS74HC943, and functionally compatible with the Texas Instruments TMS99532.

Applications include integrated and stand-alone low speed modems for terminals, personal computers, business systems, remote diagnostic systems and business machines. Since the VL7C103 is a CMOS circuit, it is ideal for built-in modems in portable or lap-top computers.

### **PIN DIAGRAM**

DSI

ALB

CD

CDT

RXD

Vcc

CDA

XTALD

**XTALS** 

RFCR

ORDER

VL7C103-PC

VL7C103-CC

Part Number

Note:

### FIGURE 1. BLOCK DIAGRAM



**VL7C103** 

1

2

3

4

5

6

7

8

9

10



# ABSOLUTE MAXIMUM

| Ambient Temperature<br>Under Bias  | - 10°C to + 80°C |
|------------------------------------|------------------|
| Storage Temperature<br>Range       | - 65°C to +140°C |
| Power Supply Voltage<br>Range      | - 0.5V to +7.0V  |
| Input Voltage Range<br>(any input) | - 0.5V to +7.0V  |
| Continuous Power                   |                  |

500mW

Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only. Functional operation of this device at these or any other conditions above those indicated on the operational sections of this specification is not implied and exposure to absolute maximum rating conditions for extended periods may effect device reliability.

Dissipation

#### 3.5795 MHz ± 0.1% RTLA XTALS XTALD TXD DATAINPUT VCCC 20 11 тха RXC DATAOUTPUT 5 0.1µF ±10% RXA2 REC 15 10 GND 10 VL7C103 TEST OUTPUT O 600Ω 100µF 0.1µF 2.2kC RXA1 CDT CDA 12 600Ω 10uF 7 6 TEST INPUT 0.1.1 Q Q +5V +5V

### **OPERATING CONDITIONS**

| Parameter | Description             | Conditions | Min   | Тур     | Max   | Units |
|-----------|-------------------------|------------|-------|---------|-------|-------|
| ТА        | Ambient Temperature     |            | 0     |         | 70    | °C    |
| VCC       | Positive Supply Voltage |            | 4.5   | 5.0     | 5.5   | V     |
| GND       | Ground                  |            |       | 0       |       | V     |
| GNDA      | Analog Ground           |            |       | 1/2 VCC |       | V     |
| FC        | Crystal Frequency       |            | 3.576 | 3.5795  | 3.583 | MHz   |
| TR,TF     | Input Rise or Fall Time |            |       |         | 500   | ns    |

# TABLE 1. BELL 103 TRANSMITAND RECEIVE TONES

|       | High Band | Low Band |  |  |
|-------|-----------|----------|--|--|
| Mark  | 2225 Hz   | 1270 Hz  |  |  |
| Space | 2025 Hz   | 1070 Hz  |  |  |

### TABLE 2. RESISTOR VALUES FOR THE ADJUSTMENT OF THE TRANSMIT LEVEL AT VCC=5.0VDC

| Line Loss (dB) | Transmit<br>Level (dBm) | Programming<br>Resistor (Rtla) |  |  |
|----------------|-------------------------|--------------------------------|--|--|
| 0              | -12                     | Open Circuit                   |  |  |
| 1              | -11                     | 19.8kΩ                         |  |  |
| 2              | -10                     | 9.2kΩ                          |  |  |
| 3              | -9                      | 5.49kΩ                         |  |  |

### FIGURE 2. VL7C103 AC SPECIFICATION CIRCUIT



### PIN DESCRIPTION

### **Pin Description**

| Pin<br>Number | Pin<br>Name | Function                                                                                                                                                                                                                                                                                                   | Pin<br>Number | Pin<br>Name | Function                                                                                                                                                                                                                                                                                       |
|---------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1             | DSI         | Driver Summing Input; used to transmit<br>externally generated tones such as<br>DTMF dialing signals. When not used,<br>this pin should be left open. See                                                                                                                                                  |               |             | to evaluate filter performance. For normal modem operation, RFCR is AC grounded (pin 19) via a 0.1 $\mu F$ bypass capacitor.                                                                                                                                                                   |
|               |             | functional description for details on how to use this input.                                                                                                                                                                                                                                               | 11            | TXD         | Transmit Data - the data input.                                                                                                                                                                                                                                                                |
| 2             | ALB         | Analog Loopback; low for normal                                                                                                                                                                                                                                                                            | 12            | GND         | Ground (0V)                                                                                                                                                                                                                                                                                    |
|               |             | modulator output to the demodulator<br>input. If ALB and SQT are<br>simultaneously held high, the chip<br>powers down                                                                                                                                                                                      | 13            | O/Ā         | Originate/Answer mode select; when high (low), this pin selects the originate (answer) mode of operation.                                                                                                                                                                                      |
| 3             | CD          | Carrier Detect output; goes low when carrier is detected.                                                                                                                                                                                                                                                  | 14            | SQT         | Squelch Transmitter; this disconnects<br>the modulator output from the line driver<br>input when held high. The EXI input,<br>however, remains active. If SQT and                                                                                                                              |
| 4             | CDT         | Carrier Detect Timing output; a<br>capacitor on this pin sets the time<br>interval that the carrier must be present                                                                                                                                                                                        |               |             | ALB are held high simultaneously, the chip will power down.                                                                                                                                                                                                                                    |
|               |             | before CD goes low. For testing<br>purposes, if this pin is connected to pin<br>12, then RFCR will be connected to the<br>output of the receive filter.                                                                                                                                                    | 15            | RXA2        | Receive Analog (2); RXA2 and RXA1<br>are analog inputs. When connected as<br>recommended, they produce a balanced<br>hybrid.                                                                                                                                                                   |
| 5             | RXD         | Received Data - the data output.                                                                                                                                                                                                                                                                           | 16            | RXA1        | Receive Analog (1); see RXA2 for details.                                                                                                                                                                                                                                                      |
| 6             | VCC         | Positive (+5V) power supply.                                                                                                                                                                                                                                                                               | 47            | TVA         | Toosaanti Amelan asidasida Baradahaa                                                                                                                                                                                                                                                           |
| 7             | CDA         | Carrier Detect Adjust input; this is used for adjustment of the carrier detect                                                                                                                                                                                                                             | 17            | IXA         | output.                                                                                                                                                                                                                                                                                        |
|               |             | threshold. Carrier detect hysteresis is<br>set at 3 dB. For testing purposes, if this<br>pin is connected to pin 12, the Transmit<br>filter can be tested by using TLA as an<br>input driven from a low output resistance<br>signal source and TXA as the output.                                          | 18            | EXI         | External Input; this is a high impedance<br>input to the line driver. This input may<br>be used to transmit externally generated<br>tones. When not used for this purpose,<br>it should be connected to pin 19. See<br>functional description for further details<br>on how to use this input. |
| 8             | XTALD       | Crystal oscillator output; should be connected to a 3.579545 MHz crystal.                                                                                                                                                                                                                                  | 19            | GNDA        | Analog Ground (1/2 VCC)                                                                                                                                                                                                                                                                        |
|               |             | clock.                                                                                                                                                                                                                                                                                                     | 20            | TLA         | Transmit Level Adjust; a resistor from this pin to VCC sets the transmit level.                                                                                                                                                                                                                |
| 9             | XTALS       | Crystal oscillator input; should be<br>connected to a 3.579545 MHz crystal.<br>If external clock is used, this pin must<br>be left open.                                                                                                                                                                   |               |             |                                                                                                                                                                                                                                                                                                |
| 10            | RFCR        | Receive Filter/Carrier Rectifier; this<br>normally connected to the output of the<br>carrier rectifier. If CDT is connected to<br>pin 12, then this pin is disconnected<br>from the rectifier and instead it will be<br>connected to a high impedance output<br>of the receive filter. It may thus be used |               |             |                                                                                                                                                                                                                                                                                                |



### FUNCTIONAL DESCRIPTION

The VL7C103 modem can be used to transmit and receive serial digital data over general switched telephone networks, leased lines, or other equivalent narrow band channels. Up to 300 bits per second can be transmitted and received simultaneously.

#### TRANSMITTER

As shown in the block diagram, the digital input data (TXD) is first modulated by the frequency shift keying (FSK) modulator. FSK modulation is performed according to Bell 103 specifications as listed in Table 1.

To separate the transmit and receive signals, the originating modern transmits in the low band while the answering modern transmits in the high band. The transmit filter smooths and band limits the modulator output. The nominal center frequency of this filter is placed at 2125 Hz or 1170 Hz depending on whether the modern is in the answer mode or in the originate mode, respectively.

The output of the transmit filter goes through the line driver and appears at TXA (Pin 17). The signal level at TXA can be controlled by connecting a resistor between TLA (Pin 20) and VCC (Pin 6). The open circuit voltage on pin 20 is 0.1 VCC. The transmitted power levels shown in Table 2 refer to the power delivered to a 6000 source impedance. The voltage on the load is half the TXA voltage.

#### RECEIVER

The analog signal received from the line is buffered by the hybrid circuit and filtered by the receive filter. The receive filter is similar to the transmit filter except that it always operates at the band opposite to the transmit filter band. When the transmit filter operates at the high band, the receive filter operates at the low band and vice versa. The output of the receive filter is hard limited and demodulated by the FSK demodulator. The demodulator output appears at RXD (Pin 5).

### **CARRIER DETECTOR**

An adaptive level detector responds to the presence of signal energy within the receive band and generates an active low logic level on the CD output (Pin 3). This circuit has a built-in hysteresis of 2dB, minimum. Typically, CD is activated when the received signal power exceeds - 44dBm (VON = 4.9mVms) and CD is deactivated when the signal drops below -47dBm (VOFF=3.5mVrms). This hysteresis prevents oscillatory operation of the carrier detector when the received signal is close to the detection threshold.

### CARRIER DETECT THRESHOLDS

The threshold levels can be changed by applying a voltage to CDA (Pin 7) according to the equation below:

VCDA = 244 X VON (Volt) VCDA = 345 X VOFF (Volt) VCDA is referenced to pin 19. The open circuit voltage on pin 7 is 0.24 VCC

Converting VON and VOFF to equivalent power level (across  $600\Omega$  resistor) in dBm:

### VCDA = 189 X 10PON/20 or

 $PON = 20 \log_{10}(VCDA/189)$ 

VCDA = 267 X 10POFF/20 or

POFF = 20 log10(VCDA/267)

where PON and POFF are in dBm and VCDA is in volts.

### **CARRIER DETECT TIMING**

To reduce the effects of impulse noise and false triggering of the carrier detector, CD only goes low (active) when a carrier is detected and present for at least a time equal to TON. Also, to deactivate CD (i.e., going from low to high), the carrier must be removed for at least a time equal to TOFF. TON and TOFF can be adjusted by proper selection of the capacitor on CDT (pin 4) according to the following equations:

#### TON ~6.4 X CCDT

#### TOFF ~0.54 X CCDT

where CCDT is in  $\mu\text{F}$  and TON and TOFF are in seconds.

#### LINE HYBRID

To attenuate the transmitted signal at TXA before it is fed back to the receiver input, TXA can be connected externally to RXA2 and also connected via a 600 ohm resistor to RXA1.

If the line impedance is also 600 ohms, then the transmit signal will appear as a common mode signal to the receiver and will effectively be eliminated. However, because the line impedance characteristics vary considerably, a perfect match with a fixed resistor rarely occurs and part of TXA is fed back to the receiver.

#### TRANSMIT SQUELCH

When SQT is held high, the transmitter will be squelched and only the signals at EXI or DSI, if any, may be transmitted. See DSI below.

### ANALOG LOOPBACK

When ALB is held high, the output of the line driver is looped back to the input of the receive filter. This feature can be used for testing the modem if the modem is in the originate mode, then the transmit and receive filters will be turned to the low band. On the other hand, when the modem is in the answer mode, both filters will tune to the high band.

### **ORIGINATE/ANSWER MODES**

When the modem is in the originate mode (O/A = high), it will transmit in the low band and receive in the high band. This situation is reversed when the modem is in the answer mode (O/A = low).

#### POWER DOWN MODE

To power down, SQT and ALB should be held high simultaneously.

#### DSI

This input can be used to transmit externally generated signals, such as DTMF tones, while the modem is in the squelched mode. The external tone should be capacitor coupled through a



resistor into this pin. The gain of the transmit amplifier will then be determined by the ratio of the on-chip feedback resistor (typically 100K ohms) and the external series resistor. Since the on-chip resistor value can vary by  $\pm 25\%$ , it is recommended that the EXI pin be used as described below for accurate control of transmitted tone level. When this pin is not used, it should be left open.

### EXI

This input can be used to transmit externally generated signals, such as DTMF tones, while the modern is in squelched mode with DSI left open. The external tone should be capacitor coupled into this pin with a resistor (typically 100k ohms) connected between this pin and analog ground (pin19). Used in this manner, the transmitted tone level is twice the input tone level since the transmit amplifier is configured internally as a gain of 2 stage. When this pin is not used, it should be connected to pin 19.

#### RFCR

This output pin is normally connected to the output of the full-wave rectifier of the carrier detect circuit. To test the output of the receive filter, CDT should be connected to pin 12 to disable the rectifier circuit. In this case, RFCR will be connected to the receive filter output and can be used for testing the receive filter.

### **CHARACTERISTICS**

Unless otherwise specified, all specifications apply to the test circuit shown in Figure 2. The demodulator specifications apply to operating VL7C103 with a modulator having frequency accuracy, phase jitter, equal to or better than the VL7C103 modulator. Typical values are at 25°C and VCC = 5.0V (Demodulator includes hybird, receive filter and discriminator.).

| Parameter                      | Conditions                       | Min. | Тур. | Max. | Units |  |  |  |  |
|--------------------------------|----------------------------------|------|------|------|-------|--|--|--|--|
| TRANSMITTER                    |                                  |      |      |      |       |  |  |  |  |
| Carrier Frequency Error        |                                  |      |      | 2    | Hz    |  |  |  |  |
|                                | VCC = 5.0V, RL = 1200Ω           |      |      |      |       |  |  |  |  |
| Power Output Delivered to Line | RTLA = 5490Ω                     |      | -9   |      | dBm   |  |  |  |  |
|                                | RTLAopen                         |      | -12  |      | dBm   |  |  |  |  |
| Second Harmonic Energy         | RTLAopen                         |      | -60  |      | dBm   |  |  |  |  |
| RECEIVE FILTER AND HYBR        | D                                |      |      |      |       |  |  |  |  |
| Hybrid Input Resistance        |                                  | 1    |      |      |       |  |  |  |  |
| (pins 15 and 16)               |                                  |      | 100  |      | kΩ    |  |  |  |  |
| RFCR Output Resistance         | Pin 10, No external Capacitor    |      | 30   |      | kΩ    |  |  |  |  |
| Adjacent Channel Rejection     | TXD = GND or VCC                 |      |      |      |       |  |  |  |  |
|                                | Input to RXA1:RXA2 = GNDA        | 60   |      |      | dB    |  |  |  |  |
| DEMODULATOR                    |                                  |      |      |      |       |  |  |  |  |
| Maximum Carrier Amplitude      |                                  |      | -12  |      | dBm   |  |  |  |  |
| Minimum Carrier Amplitude      |                                  |      | -47  |      | dBm   |  |  |  |  |
| Dynamic Range                  |                                  |      | 35   |      | dB    |  |  |  |  |
|                                | SNR=30dB                         |      |      |      |       |  |  |  |  |
| Bit Jitter                     | Input = -38dBm                   |      |      |      |       |  |  |  |  |
|                                | Baud Rate = 300                  |      | 100  |      | μs    |  |  |  |  |
| Bit Bias Distortion            |                                  |      | 5    |      | %     |  |  |  |  |
| Carrier Detect Trip Points     | CDA = 1.2V (Referenced Off to On |      | -44  |      | dBm   |  |  |  |  |
|                                | to pin 19) On to Off             |      | -47  |      | dBm   |  |  |  |  |


| Parameter | Description               | Conditions                               | Min            | Тур | Max  | Units  |
|-----------|---------------------------|------------------------------------------|----------------|-----|------|--------|
| VIH       | High Level Input Voltage  |                                          | 3.15           |     |      | V .    |
| VIL       | Low Level Input Voltage   |                                          |                |     | 1.0  | v      |
|           |                           | VIN = VIH or VIL                         |                | ÷   |      |        |
| VOH       | High Level Output Voltage | IOUT  = 20μA<br> IOUT  = 4mA, VCC = 4.5V | VCC-0.1<br>3.7 | VCC |      | v<br>v |
|           |                           | VIN = VIH or VIL                         |                |     |      |        |
| VOL       | Low Level Output Voltage  | IOUT  = 20µA                             |                |     | 0.1  | v      |
|           |                           | IOUT  = 4mA, VCC = 4.5V                  |                |     | 0.4  | v      |
|           | х.                        | IOUT  = 15mA (Pin 3)                     |                |     | 0.5  | v      |
| liN       | Input Current             | VIN = VCC or GND                         |                |     | ±1.0 | μA     |
| ICC       | Quiescent Power Supply    | ALB or SQT = GND                         | 1              |     |      |        |
|           | Current                   | Transmit Level = -9dBm                   |                | 8   | 1    | mA     |
|           |                           | ALB = SQT = VCC                          |                |     |      |        |
| ICC       | Power Down Supply Current | VIH=VCC                                  |                |     | 250  | μA     |
|           |                           | VIL = GND                                |                |     |      |        |

#### DC CHARACTERISTICS TA= 0°C to +70°C, VCC= 5V $\pm$ 10%, GND= 0V, Typical values are for 25 °C

FIGURE 3. VL7C103 AC SPECIFICATION CIRCUIT



7-8



#### TYPICAL APPLICATION

÷





# VL7C211



## 212A/V.22 MODEM FILTER

#### FEATURES

- Transmit-and-Receive filter with half-channel compromise amplitude and group delay equalization
- Built-in Call Progress Mode and Answer / Originate Mode switching
- Bell 212A and CCITT V.22 compatible, with V.22 notch filters included
- Analog loop-back capability for in circuit testing
- Improved data transmission characteristics for lower bit error rate
- No external logic or multiplexers required
- Supports both North American and European modem designs

#### DESCRIPTION

The VL7C211 modem filter is a monolithic CMOS switched-capacitor filter circuit designed for use in full-

#### **PIN DIAGRAM**



duplex 1200-bit-per-second modems. It meets the filtering requirements of the Bell 212A and CCITT V.22 modem specifications and includes high-band (2400 Hz) and low-band (1200 Hz) filters, half-channel compromise amplitude and group delay equalizers for both bands. and smoothing filters for both bands. For CCITT V.22 applications, a notch filter is included that can be programmed for either 550 Hz or 1800 Hz. Also included in the VL7C211 filter are two uncommitted operational amplifiers that can be used for anti-aliasing filters or for gain control.

The VL7C211 is pin and function compatible with the Sierra SC11005, the AMI S35212 and S35212A. Further, the high-band filter in this filter can be scaled by a factor of six so that it can be used to monitor call progress tones in an intelligent modern. And, like the

### **BLOCK DIAGRAM**

S35212A, it contains analog loop-back so that the signal path can be completely tested.

The VL7C211 offers enhanced call progress monitoring features and is pin and function compatible with the Sierra SC11001. It contains two pins, CPM (pin 12) and NFI (pin 13), that allow more accurate call progress monitoring and easier V.22 implementation without the need for extra multiplexers or logic. Besides being able to scale the highband filter by a factor of six, the lowband filter can be scaled by a factor of 2.5 for better centering over the call progress frequency range of from 300 to 660 Hz. It also allows the unscaled highband filter to be used for monitoring the modem answer tone, simplifying the design of full auto-dial / auto-answer modems.



1. Pins 1, 4, 11, 12, 13, 17, and 22 have internal pull-down resistors to ground. 2. Pin 14 has an internal pull-up to VCC.

in 14 has an internal pull-up to VCC.

#### ORDER INFORMATION

| Part<br>Number           | Package                                              |
|--------------------------|------------------------------------------------------|
| VL7C211-PC<br>VL7C211-QC | Plastic DIP<br>Plastic Leaded<br>Chip Carrier (PLCC) |

Note: Operating temperature range: 0°C to +70°C.



#### FIGURE 1. BLOCK DIAGRAM







#### SIGNAL DESCRIPTIONS

|            |             |                                                                         | RATINGS                           |
|------------|-------------|-------------------------------------------------------------------------|-----------------------------------|
| Pin Number | Signal Name | Description                                                             | nannao                            |
| 1          | SEL2        | Call progress mode selection LOW for normal operation, HIGH for scaling | Ambient Temper<br>10°C to +80-    |
|            |             | the high-band filter by six for call progress                           | Storage Temper                    |
| 2          | Vee         | monitor.<br>Negative supply voltage                                     | -05°C t0 +14<br>Operating Temp    |
| 2          | RXin        | Receive signal input                                                    | (Plastic DIP                      |
| 4          | CLK1        | Clock input 1:2 4576 MHz with SEL1 HIGH                                 | $0^{\circ}$ to $\pm 70^{\circ}$ C |
| -          | OLIVI       | or 1 2288 MHz with SEL1 LOW                                             | Maximum Supple                    |
| 5          | Bout        | Output of the B amplifier                                               | VCC = +7V                         |
| ő          | B-          | Inverting input of the R amplifier                                      | VSS = -7 V                        |
| 7          | B+          | Non-inverting input of the R amplifier                                  | Input Analog Vol                  |
| 8          | VCC         | Positive supply                                                         | (pins 3, 6, 7,                    |
| 9          | SEL1        | Selects clock frequency into pin 4; LOW                                 | VCC + 0.6 V                       |
|            |             | for 1.2288 MHz or HIGH for 2.4576 MHz.                                  | VSS - 0.6 V                       |
| 10         | AGND        | Analog ground                                                           | Input Digital Volt                |
| 11         | A/Ō         | Answer / originate mode selection; HIGH                                 | (pins 1, 4, 9                     |
|            |             | for answer, LOW for originate.                                          | 14, 17,22)                        |
| 12         | CPM         | Enhanced call progress mode selection                                   | VCC + 0.6 \                       |
|            |             | LOW for normal operation; HIGH to                                       | VSS - 0.6 V                       |
|            |             | scale down the low-band filter by 2.5 for                               | Maximum Powe                      |
|            |             | enhanced call progress monitoring.                                      | (Plastic DIP                      |
| 13         | NFI         | Notch filter insert; LOW for notch filter                               | 500 mW @                          |
|            |             | bypass, HIGH to insert notch filter.                                    |                                   |
| 14         | ALB         | Analog loop-back; HIGH for normal                                       | Stresses above                    |
|            |             | operation, LOW to loop-back TXout                                       | "Absolute Maxim                   |
| . –        |             | to RXin.                                                                | cause permaner                    |
| 15         | TXout       | Transmit signal output                                                  | device. These a                   |
| 16         | NFO         | Notch filter output                                                     | Functional opera                  |
| 17         | NSEL        | Notch filter selection; LOW for 550 Hz,                                 | under these or a                  |
| 40         |             | HIGH for 1800 Hz.                                                       | those indicated i                 |
| 18         | I Xin       | I ransmit signal input                                                  | not implied. Exp                  |
| 19         |             | Output of the Tampiner                                                  | maximum rating                    |
| 20         | 1+<br>T     | Non-inverting input to the Tamplifier                                   | extended period                   |
| 21         | 1-<br>CI K2 | Clock input 2: 152 6 KHz                                                | reliability.                      |
| 22         |             | Digital ground                                                          |                                   |
| 23         | BYout       | Digital ground<br>Receive signal output                                 |                                   |
| 24         | n AOUL      | neceive signal output                                                   |                                   |

#### ABSOLUTE MAXIMUM RATINGS

rature Under Bias 0°C rature Range 40°C erature Range , PLCC) ly Voltage Itage Range 18, 20, 21) V Max Min tage Range , 11, 12, 13, V Max Min r Dissipation PLCC) 25°C those listed under num Ratings" may nt damage to the re stress ratings only. ation of the device any conditions above in this data sheet is osure to absolute

| maximum rating conditions for    |    |
|----------------------------------|----|
| extended periods may affect devi | се |
| reliability.                     |    |

#### DC CHARACTERISTICS TA = 0°C to 70°C, VCC = $5.0 \text{ V} \pm 10\%$ unless otherwise noted

| Symbol | Parameter Co                                                                        | Conditions                                                                 | Min | Тур | Max | Units |
|--------|-------------------------------------------------------------------------------------|----------------------------------------------------------------------------|-----|-----|-----|-------|
| ICC    | +5V Quiescent Current                                                               | No Load                                                                    |     | 7.5 | 15  | mA    |
| ISS    | -5V Quiescent Current                                                               | No Load                                                                    |     | 7.5 | 15  | mA    |
| VIH    | High Level Input Voltage;<br>Digital Signal pins 1, 4, 9,<br>11, 12, 13, 14, 17, 22 |                                                                            | 2.0 |     |     | v     |
| VIL    | Low Level Input Voltage;<br>Digital Signal pins 1, 4, 9,<br>11, 12, 13, 14, 17, 22  |                                                                            |     |     | 0.8 | v     |
| VOMAX  | Output Signal;<br>pins 5, 15, 16, 19, 24                                            | VCC=+5V, VSS=-5V,<br>RL = 10kΩ (pins 5, 19)<br>RL = 20kΩ (pins 15, 16, 24) | ±3  |     |     | v     |



| Parameter                    | Conditions                            | Min  | Тур | Max  | Units  |
|------------------------------|---------------------------------------|------|-----|------|--------|
| Output Noise RXout, TXout    |                                       |      | 30  | 33   | dBrnC0 |
| Crosstalk                    |                                       | 55   | 60  |      | %      |
| Total Harmonic Distortion    |                                       |      | 0.3 |      | dB     |
| Dynamic Range                | · · · · · · · · · · · · · · · · · · · |      | 70  |      | dB     |
| Adjacent Channel Rejection:  |                                       |      | 1   |      | dB     |
| Low-Band                     |                                       | 55   | 65  |      | dB     |
| High-Band                    | · · · ·                               | 55   | 75  |      | dB     |
| Passband Gain at Center      |                                       |      |     |      |        |
| Frequency (1200 Hz, 2400 Hz) |                                       | -1   |     | +1   | dB     |
| Relative Gain: Low-Band      | @300 Hz                               |      | 1   | -35  | dB     |
| Reference = 1200 Hz          | @800 Hz                               | -1   |     | -1   | dB     |
|                              | @1600 Hz                              | -1.5 | 1   | +1   | dB     |
|                              | @1800 Hz                              | · ·  |     | -18  | dB     |
|                              | @2000 Hz                              |      |     | -48  | dB     |
|                              | @2400 Hz                              |      |     | -55  | dB     |
|                              | @2800 Hz                              |      |     | -50  | dB     |
| Relative Gain: High-Band     | @800 Hz                               |      |     | -50  | dB     |
| Reference = 2400 Hz          | @1200 Hz                              |      |     | -53  | dB     |
|                              | @1600 Hz                              |      |     | -50  | dB     |
|                              | @2000 Hz                              | -2.5 | 1   | +0.5 | dB     |
|                              | @2800 Hz                              | 0    |     | +2.5 | dB     |
|                              | @3200 Hz                              |      |     | -10  | dB     |
|                              | @3500 Hz                              |      |     | -20  | dB     |
| Relative Gain: Low-Band      | @550 Hz, NSEL = LOW                   |      |     | -45  | dB     |
| NFI = HIGH                   | @1800 Hz, NSEL = HIGH                 |      |     | -45  | dB     |

#### FUNCTIONAL DESCRIPTION LOW-BAND FILTER

The low-band filter is a 10th-order, switched-capacitor, band-pass filter with a center frequency of 1200 Hz. (See figure 3 for the amplitude response of this filter.) In the originate mode, this filter is used in the transmit direction; in the answer mode, it is used in the receive direction. When analog loop-back is used in the originate mode, this filter, together with the low-band delay equalizer is in the test loop. In the call progress monitoring mode with SEL2 (pin 1) HIGH and CPM (pin 12) LOW, the center frequency of this filter is shifted down by a factor of six to 200 Hz. If pin 12 (CPM) is HIGH, the filter response is scaled down by 2.5, moving the center frequency to 480 Hz.

#### LOW-BAND DELAY EQUALIZER

The low-band delay equalizer is a 10thorder, switched-capacitor, all-pass filter that compensates for the group delay variation of the low-band and half of the compromise line characteristics, producing a flat delay response within the pass-band. (See figure 4 for the group delay response of the low-band filter cascaded with the low-band delay equalizer.)

#### HIGH-BAND FILTER

The high-band filter is a 10th-order switched-capacitor, band-pass filter with a center frequency of 2400 Hz. (See figure 5 for the amplitude response of this filter.) In the answer mode, this filter is used in the transmitter direction; in the receive mode, it is used in the receive direction. When analog loop-back is used in the answer mode, this filter, together with the high-band delay equalizer, is in the test loop. In the call



progress monitoring mode with SEL2 (pin 1) HIGH and CPM (pin 12) LOW, the center frequency is shifted down by a factor of six to 400 Hz. If pin 1 is LOW or pin 12 is HIGH, this filter operates in the normal data mode.

#### HIGH-BAND DELAY EQUALIZER

The high-band delay equalizer is a 10thorder, switched-capacitor, all-pass filter that compensates for the group delay variation of the high-band filter and half of the compromise line characteristics, producing a flat delay response for the high-band filter cascaded with the high-band delay equalizer.

## TRANSMIT SMOOTHING FILTER

The transmit smoothing filter is a firstorder, low-pass switched-capacitor filter.

#### **RECEIVE SMOOTHING FILTER**

The receive smoothing filter consists of a second-order, low-pass switchedcapacitor filter cascaded with a second-order, active R-C, low-pass filter.

#### **V.22 NOTCH FILTER**

The V.22 notch filter is a second order, switched-capacitor notch filter. The center frequency of the filter is at 550 Hz when NSEL (pin 17) is LOW, and is shifted to 1800 Hz when NSEL is HIGH. This filter is bypassed in the low band if NFI (pin 13) is LOW. Its output, however, is always available at pin 16 (NFO).

#### UNCOMMITTED OPERATIONAL AMPLIFIERS

Two operational amplifiers, called the R amplifier and the T amplifier, are included as a part of the VL7C211. They are not used by the filter circuit and can be used, for example, as antialiasing filters or gain stages in a complete 212A modem circuit.

#### ANALOG LOOP-BACK

When ALB (pin 14) is LOW, the signal transmitted by the modern TXin is looped back to the modern through the RXout pin. If the low (high)-band filter / equalizer is to be tested, the A/O pin should be LOW (HIGH). The receive smoothing filter is in this loop regardless of the A/O level. An internal pull-up resistor keeps this pin HIGH when it is not connected externally.

#### ANSWER / ORIGINATE MODE SELECTION

When  $A\overline{O}$  (pin 11) is LOW, the modem operates in the originate mode, transmitting in the low band and receiving in the high band. If  $A/\overline{O}$  is HIGH, the modem operates in the answer mode, transmitting in the high band and receiving in the low band. An internal pull-down resistor keeps this pin LOW when it is not connected externally.

#### CLOCK SELECTION

SEL1 (pin 9) is used to select the correct internal divider, depending on the frequency of the external clock. SEL1 is set HIGH for use with a 2.4576 MHz clock input on CLK1 (pin 4), and set LOW for a 1.2288 MHz input on CLK1. If a 153.6 KHz clock is used on CLK2 (pin 22), CLK1 (pin 4) should be left open.

#### NORMAL / CALL PROGRESS MODE

When SEL2 (pin 1) and CPM (pin 12) are LOW, the filter operates in the norm-al data mode. When either pin is HIGH, the filter operates in the call progress monitoring mode. When SEL2 is HIGH and CPM is LOW, the center frequencies of both the lowband and the high-band filters are shifted down to one-sixth of the frequencies used in the normal data mode. SEL2 is internally pulled down to keep it at a LOW level when it is not connected externally.

When CPM is HIGH, the low-band filter is scaled down by a factor of 2.5 (figure 7) and RXout is the output of either the scaled low-band filter, or the unscaled high-band filter, depending on the logic levels at  $\overline{ALB}$  (pin 14) and  $\overline{A/O}$  (pin 11), as shown in table 1.

#### TRANSMIT SQUELCH IN CALL PROGRESS MODE

When CPM is HIGH (call progress mode), the input of the transmit smoothing filter is disconnected and shorted to ground, squelching the transmitter. In the handshake sequence of a 212A modem, this feature can be used to eliminate any transmit signal output. An internal pulldown resistor keeps the CPM pin LOW when it is not connected externally.

#### APPLICATIONS MODES OF OPERATION

The VL7C211 filter can be operated in three basic modes: a normal data mode, a test mode, and a call progress monitor mode.

#### NORMAL DATA MODE

Figures 8 through 11 illustrate the signal flow diagrams for the filter in the normal data mode for either a 212A or a V.22 modem. In the originate mode, the transmit signal goes through the low-band filter and the receive signal goes through the high-band filter. In the answer mode, the transmit signal goes through the high-band filter and receive signal goes though the bowband filter.

#### TEST MODE

The filter can be tested by entering the analog loop-back mode, as illustrated in figures 12 and 13. In this mode, the transmit signal is looped back to the RXout pin after going through either the low-band filter or the high-band filter, depending on originate or answer mode selection. The analog loop-back mode facilitates testing of the modem locally, without having to make a data call.

#### CALL PROGRESS MONITOR MODE

This filter operates in one of two different call progress monitoring modes, depending on whether the SEL2 or CPM pin is HIGH. If SEL2 is HIGH the center frequency of both the low-band and the high-band filters is shifted down by a factor of six and the bandwidth of the filters is also reduced by a factor of six. Thus, the high-band filter is shifted down to 400 Hz ± 80 Hz. while the low-band filter is shifted down to 200 Hz ± 80 Hz. By selecting the originate mode, the receive signal goes through the modified high-band filter, which now has a pass-band of approximately 300 Hz to 480 Hz. This allows precision dial tone of 350 / 440 Hz as well as audible ringing tone of 440 / 480 Hz to pass. However, only a portion of the busy or reorder tone of 480 / 620 Hz passes through. An external energy detector circuit, combined with a method of cadence and timing determination. distinguishes between different conditions on the line during establishing a call.



FIGURE 2. LOW-BAND AND HIGH-BAND RESPONSE, NORMALIZED



FIGURE 3. LOW-BAND RESPONSE, NORMALIZED





#### FIGURE 4. LOW-BAND GROUP DELAY (Hz)



FIGURE 5. HIGH-BAND RESPONSE, NORMALIZED





#### FIGURE 6. HIGH-BAND GROUP DELAY (Hz)



FIGURE 7. LOW-BAND DIVIDED BY 2.5 AMPLITUDE RESPONSE, NORMALIZED





#### FIGURE 8. 212A ORIGINATE MODE



FIGURE 9. 212A ANSWER MODE



FIGURE 10. V.22 ANSWER MODE





FIGURE 11. V.22 ORIGINATE MODE



MUX

13

A/O

ō

11

ALB

ō

14

SEL2

×

1

NFI

ō

FIGURE 12. 212A ANALOG LOOP-BACK MODE UISNG LOW-BAND FILTER (ORIGINATE MODE)



FIGURE 13. 212A ANALOG LOOP-BACK MODE USING HIGH-BAND FILTER (ANSWER MODE)



FIGURE 14. CALL PROGRESS MONITOR MODE: MONITORING ANSWER TONE/VOICE





СРМ

12

7-20

CLK2

153.6kHz

22

MUX

CLK1

N/C

4

15

24

-M

SEL1

N/C

9

Smoothing Filters

NSEL

×

17

llh

#### TABLE 1. OPERATING MODES

| Mode | CPM | SEL2 | ALB | A/O | TXIN | TXOUT | RXIN        | RXOUT |
|------|-----|------|-----|-----|------|-------|-------------|-------|
| 0    | 0   | 0    | 1   | 0   | L    | L     | Н           | Н     |
| 1    | 0   | 0    | 1   | 1   | Н    | Н     | L           | L     |
| 2    | 0   | 0    | 0   | 0   | L    | L     | Н           | н     |
| 3    | 0   | 0    | 0   | 1   | Н    | н     | L           | н     |
| 4    | υ   | i    | 1   | 0   | L/6  | L/6   | H/6         | H/6   |
| 5    | 0   | 1    | 1   | 1   | H/6  | H/6   | L/6         | L/6   |
| 6    | 0   | 1    | 0   | 0   | L/6  | L/6   | H/6         | L/6   |
| 7    | 0   | 1    | 0   | 1   | H/6  | H/6   | L/6         | H/6   |
| 8    | 1   | х    | 1   | 0   | -    | SQT   | (L/2.5 + H) | Н     |
| 9    | 1   | х    | 1   | 1   | н    | SQT   | L/2.5       | L/2.5 |
| 10   | 1   | Х    | 0   | 0   | -    | SQT   | (L/2.5 + H) | L/2.5 |
| 11   | 1   | X    | 0   | 1   | н    | SQT   | L/2.5       | Н     |

Note:

1. "L" refers to a center frequency of 1200Hz.

2. "H" refers to a center frequency of 2400 Hz.

3. SQT means the transmitter output is squelched.

4. - refers to no filter connection.

5. + means connection to both filters.

6. X means "don't care".

7. By switching between modes 8 and 10, the filter can be used to detect reception of the call progress tones in the L/2.5 band as well as the answer tone in the <u>H</u> band.

8. The SEL2 (pin 1), CPM, ALB (pin 14) and A/O (pin 11) control the modes of operation of the filter as shown in table 1. For each combination of these pins, the table shows to which each filter input and output is connected. The "L" refers to the low-band filter with the response shown in figure 2. The "H" is used to denote the high-band filter as characterized in figure 2. When L or H is divided by a factor of six (or 2.5), this is indicated by L/6 or H/6, meaning that the frequency response is scaled down by six.

The VL7C211 features an additional mode for monitoring the call progress tones. This mode is initiated by taking the CPM pin HIGH. Two deficiencies. inherent in the first mode described above, are overcome in this enhanced mode. First, the pass-band is more accurately centered over the call progress tone frequencies because the low-band filter is scaled down by a factor of 2.5. The low-band filter thus has a pass-band of from 290 Hz to 670 Hz. which allows the busy tone to pass through completely. Second, since the high-band filter is not scaled, answer tones can be easily monitored.

The receive signal is connected to both the high-band filter and the scaled lowband filter. By toggling the ALB pin between HIGH and LOW levels, either the answer tone or the call progress tone can be monitored on the RXout pin. Figures 14 and 15 show the signal flow diagrams in the call progress monitor

mode. A method for determining conditions on the line during establishing a call is described in the following section.

#### CIRCUIT DESCRIPTION

In the circuit of Figure 16, op amps U1 and U2 and resistors R8 through R13 form a 2- to 4-wire converter that separates the line signal into the transmit and receive components. The receive signal is connected to the RXin input of the VL7C211 filter. In the call originate mode the signal goes through the high-band filter and comes out on the RXout pin. For call progress monitoring, the low-band filter operates in a scaled mode, thus filtering the receive signal over the range of from 290 Hz to 670 Hz. Op amps U3 and U4, comparator U5, and associated discrete components form the energy detector. U3 operates as a full-wave rectifier. U4 is a buffer that drives a low-pass filter formed by R18 and C4. The filtered signal is compared to a level set by R19 and R20. The output of U5 goes HIGH if the signal level exceeds the level set by R19 and R20. This output corresponds to the cadence information in the call proress tone signals and can be sampled by the controller according to the detection algoithm.



#### TABLE 2. CALL PROGRESS TONE CHARACTERISTICS

| Call Progress Tone | Hz                                                         | Cadence                            |
|--------------------|------------------------------------------------------------|------------------------------------|
| Dial Tone          | 350 + 440*<br>400, 425<br>600 x 120 IPS**                  | Continuous steady tone             |
| Audible Ring       | 440 + 480*<br>400, 450<br>420 x 40 IPS**<br>400 x 25 IPS** | 2 s on/ 4 s off<br>1 s on/ 3 s off |
| Busy (Station)     | 480 + 620*<br>400, 425, 450<br>600 x 120 IPS**             | 0.5 s. on/ 0.5 s. off              |
| Busy (circuit)     | Same as above                                              | 0.25 s on/ 0.25 s off              |
| Off Hook Alert     | Multifrequency                                             | 1 s/1 s                            |

Notes:

\*Precision tones specified by AT&T

\*\* IPS means interruptions per second.

FIGURE 16. A CALL PROGRESS MONITORING APPLICATION



The rest of the circuitry in figure 16 performs the function of the data access arrangemetn (DAA). Transformer T1 provides isolation and sinks the line current in the off-hook state. R1, R2, V1, Z3, and Z4 provide surge protection. Relay KR1 and transistor Q1 control on-hook / offhook conditions. C1, R3, Z1, Z2, D1 and OC1 limit and rectify the high-

voltage ac ringing signal; OC1 provides isolation, R4 and C2 filter the rectified ring signal, and Schmidt trigger IC U6 converts it into a logic level for the controller.

#### A CALL PROGRESS MONITORING APPLICATION

Figure 16 shows a schematic for using the VL7C211 filter in a call progress monitoring application. Specifically, this arrangement is well-suited for implementing an intelligent 212A or V.22 modem. The modem can be designed to be either stand-alone with RS-232 interface to DTE or integrated into a computer with a parallel bus interface. It is assumed that a controller is available that can control the various operating modes of the filter, monitor the output of the energy



#### FIGURE 17. CALL PROGRESS MONITORING ALGORITHM





detector and ring indicator and control the switch-hook relay in the data access arrangement. This appli-cation illustrates how the modem filter can be used with a minimum of external circuitry to implement a fully automatic call establishment procedure.

Table 2 summarizes various call progress tone frequencies and their cadences. A call progress monitoring algorithm based on timing and cadence characteristics is described in the flow chart of figure 17.

#### **DETECTION ALOGRITHM**

Figure 17 shows the flowchart of a detection algorithm that utilizes the features provided in the VL7C211 filter and that uses the cadence information contained in the call progress tones to determine the status of the line. The main criterion in this algorithm was the degree of reliability it provides, rather than the speed with which it executes. For instance, dial tone is detected only when the output of the tone detector iscontinuously HIGH for at least onesecond.

If a dial tone is not detected within five seconds of going off-hook, the call is aborted. Many dialers do not wait for the initial dial tone and begin dialing as soon as going off-hook. This is termed blind dialing and is avoided in this algorithm.

Once the dial tone is detected, the first digit is dialed using the tone mode. Provision is made to check the absence of the dial tone after the first digit is dialed. If dial tone remains on the line, the controller can either hang up the line or try to dial using rotary pulse dialing. If a dial tone is absent, the rest of the digits can be pulse dialed.

The algorithm waits for one second after dialing is done to monitor the energy detector. This ensures that any clicks on the line donot cause a false detection. The  $\overline{ALB}$  pin of the filter is then toggled at a 100 millisecond rate and the energy detector output is sampled to see if there is energy in the call progress band. A five second timer is started and the number of transitions of the ED output is counted (N). The cumulative duration in which the ED output is in the HIGH state is also measured (T).

The algorithm makes a determination of various conditions based on N and T. The line is determined to be busy if N exceeds 7. If N is less than 7 and T is in the range of 0.7 - 3.8 seconds, the signal is determined to be audible ringing. The controller can then count the ring cycles or start a timer. It can choose to hang up if the timer overflows or if the number of ring cycles exceeds a preset value. Any other value of N or T is classified as unknown response and is left to the controller to take the next action.

If energy is detected in the high band, the ED output is monitored to see if it is continuously HIGH for at least one second. If so, this is interpreted as the distant modem answer tone, indicating that the connection is made. If not, it indicates either silence or voice. In either case, the controller can terminate the call and take the next step. Minor variations of this algorithm or fine tuning of the decision values can provide the designer with the flexibility needed to deal with different situations. It should be emphasized that the algorithm does not stand alone and must be integrated into the application software for satisfactory performance.

## **VL7C212A**



## 300/1200 BIT PER SECOND MODEM

#### FEATURES

- FSK and PSK modulators and demodulators, high-band and lowband filters with compromise amplitude and group delay equalizers
- Built-in call progress mode and tone generators for DTMF and V.22 quard tones
- Bell 212A and CCITT V.22 compatible: V.22 notch filters included
- Serial control interface
- Programmable audio output port
- Analog, digital and remote digital loopback capabilities
- 24 pin DIP and Plastic Leaded Chip Carrier packaging available

#### BENEFITS

- High level of integration provides highly cost effective 300/1200 bit per second modems
- Eliminates external components easing design of intelligent modems
- Usable in North American and European modem designs
- Simple board layout
- Simple speaker interface for monitorina phone line
- Testable signal path
- Reduced board area

#### **GENERAL DESCRIPTION**

The VL7C212A is a complete 300/1200 bit per second modem. All of the signal processing functions needed for a full duplex. 300/1200 bit per second 212A or V.22 modem, including the FSK and PSK modulators and demodulators and the high-band and low-band filters, are integrated on a single chip. Built with VTI's three micron CMOS double polysilicon process that allows analog and digital functions to be combined on the same chip, it includes capabilities for progress monitoring and for generating DTMF as well as V.22 guard tones. The two-to-four wire hybrid is also included, simplifying the interface to a DAA. The VL7C212A also includes analog loopback and remote digital loopback functions for self-testing.



| ORDER INFORMATION |                     |  |  |  |
|-------------------|---------------------|--|--|--|
| Part<br>Number    | Package             |  |  |  |
| VL7C212A-PC       | Plastic DIP         |  |  |  |
| VL7C212A-QC       | Plastic Leaded      |  |  |  |
|                   | Chip Carrier (PLCC) |  |  |  |

Note: Operating temperature range:0°C to 70°C

#### ASYNC SYNC. SCRAMBLER PSK MODULATOR туп мих PRE-FILT. FSK MODULATOR NOTCH LOW-BAND FILT, & EQI мих FII TER HIGH-BAND FILT. & FOL ENERGY TRANSMIT HYBRID & TXout DETECTOR

FIGURE 1. BLOCK DIAGRAM



# VL7C212A

#### FIGURE 2. WAVEFORMS FOR WRITE AND READ CYCLES



#### ABSOLUTE MAXIMUM RATINGS

Ambient Temperature Under Bias:  $-10^{\circ}$ C to  $+80^{\circ}$ C Storage Temperature Range:  $-65^{\circ}$ C to  $+140^{\circ}$ C Maximum Supply Voltage: VCC = +7.0VVSS = -7.0VInput Voltage Range: Analog Pins; VSS-0.6V to VCC+0.6V Digital Pins; DGND-0.6V to VCC+0.6V Maximum Power Dissipation @25^{\circ}C: 500mW

Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only. Functional Operation of this device at these or any other conditions above those indicated on the operational sections of this specification is not implied and exposure to absolute maximum rating conditions for extended periods may effect device reliability.

#### DC CHARACTERISTICS TA= 0°C to +70°C, VCC= 5V ±5%, VSS= 0V, unless otherwise specified

| Symbol | Parameter                 | Conditions                          | Min  | Тур        | Max  | Units |
|--------|---------------------------|-------------------------------------|------|------------|------|-------|
| VCC    | Positive Supply Voltage   |                                     | 4.5  | 5.0        | 5.5  | V     |
| VSS    | Negative Supply Voltage   |                                     | -4.5 | -5.0       | -5.5 | v     |
| ICC    | Quiescent Current         | VCC=5V                              |      | 15         |      | mA    |
| ISS    | Quiescent Current         | VCC = -5V                           |      | 15         |      | mA    |
| Vih    | HIGH Level Input Voltage  | Digital Signal Pins: RD, WR, D I/O, | 2.0  |            |      | v     |
|        |                           | SCK,TXCK1,TXD                       |      |            |      |       |
| Vil    | LOW Level Input Voltage   | Digital Signal Pins: RD, WR, D I/O  |      |            | 0.8  | v     |
|        |                           | SCK, TXCK1, TXD                     |      |            |      |       |
| Voh    | HIGH Level Output Voltage | (D S Pins: D I/O, CKOUT, @loh=40μA  | 4.0  |            |      | v     |
|        |                           | RXD, TXCK0, RXCK) @loh=500µA        | 2.0  |            |      | v     |
| Vol    | LOW Level Output Voltage  | (D S Pins: D I/O, CKOUT, @lol=160µA |      |            | 0.4  | v     |
|        |                           | RXD, TXCK0, RXCK)                   |      | - <i>2</i> |      |       |
| Vom    | Maximum Output Signal     | TXout, RL=1200Ω (TLC1=1, TLC0=0)    | 4.0  |            |      | Vp-p  |
|        |                           | Audio Out, RL=50 kΩ                 | 1.0  |            |      | Vp-р  |
| Vim    | Maximum Input Signal      | RXA1, RXA2                          |      |            | 2.0  | Vp-р  |

#### DESCRIPTION (Continued)

With the addition of a digital controller, such as an 8-bit microcontroller and a data access arrangement (DAA), a highly cost effective, integrated, intelligent modem can be built. When used with the VTI VL7C213A modem controller, which is an 8-bit processor combined with a UAR I, a complete Hayes command set compatible modem can be configured, taking up a minimum of board area. For stand-alone applications, the VL7C212A modem, the VL7C213 controller, a DAA and an RS232-interface are all that are required.

The VL7C212A is truly a modem on a chip. All of the signal processing functions needed for a full duplex, 300/1200 bps Bell 212A or CCITT V.22 modem are integrated on a single chip. It operates in a synchronous or asynchronous mode and handles 8, 9, 10, or 11 bit words.

Like all modems, the VL7C212A needs a controller to determine the mode of operation, initiate the call to the remote modem (either pulse or tone dialing), set up the handshaking sequence with the remote modem, monitor the call progress tones on the line (ringing, busy, answer tone and voice) and switch into the data mode. A simple four-line serial data interface was designed for the VL7C212A, enabling it to work with just about any 8-bit microcontroller or microprocessor. The control lines are: DATA INPUT/OUTPUT, SHIFT CLOCK, READ and WRITE.

#### FUNCTIONAL DESCRIPTION OF THE VL7C212A MODEM

Major sections of the VL7C212A modem are a transmitter, a receiver, low-band and high-band filters, a two-to-four wire hybrid, tone generators and interface logic. It also contains an energy detector that's used for detecting the carrier and call progress monitoring and an audio output for monitoring the line.

The VL7C212A modem requires plus and minus five volts and is available in a 24 pin DIP as well as a 28 lead plastic chip carrier with "J" leads for surface mount applications. The transmitter section consists of an async/sync converter, scrambler, PSK modulator and FSK modulator. In the high speed mode (1200 bps), the PSK modulator is connected to the filter. In the low speed mode (300 bps), the FSK modulator is connected to the filter.

#### TRANSMITTER

Since data terminals and computers may not have the timing accuracy required for 1200 bps transmission (0.01%), timing correction on the incoming data stream must be made. The async/sync converter accepts asynchronous serial data clocked at a rate between 1200 Hz + 1%, -2.5%. It outputs serial data at a fixed rate of 1200 Hz +/- 0.01% derived from the master clock oscillator. To compensate for the input and output rate differences. a stop bit is either deleted or inserted when necessary. If the input data rate is slower than the output data rate, a stop bit is inserted. If the input data rate is faster than the output data rate. a stop bit is deleted. The output of the async/sync converter is applied to the scrambler.

The scrambler is a 17 bit shift register clocked at 1200 Hz. Outputs from the 14th and 17th stages are exclusive OR'd and further exclusive OR'd with the input data. The resultant data is supplied to the D input of the shift register. Outputs from the first two stages of the shift register form the dibit that is applied to the PSK modulator. The purpose of the scrambler is to randomize data so that the energy of the modulated carrier is spread over the band of interest -- either the high-band centered at 2400 Hz or the low-band. centered at 1200 Hz. A 1200 bps modem actually sends two bits at a time, called a dibit; dibits are sent at 600 baud, the actual rate of transmission; 600 baud is the optimum rate that can be transmitted over the general switched telephone network for a full duplex FDM (frequency division multiplexing) modem because band limit filters in the central office cut off at about 3000 Hz.

The dibit applied to the PSK modulator produces one of four differential phase shifts of the square wave carrier signal (1200 Hz or 2400 Hz) at the 600 Hz baud rate. The resultant waveform is passed through a wave shaping circuit that performs a raised cosine function (this is the shape factor called out in the

# VL7C212A

CCITT V.22 spec, and it also meets the Bell 212A requirement for optimum transmission). The wave shaped signal is then passed through either the lowband or high-band filter depending upon originate or answer mode selection.

For low speed operation the FSK modulator is used. It produces one of four precision frequencies depending on originate or answer mode and the 1 (mark) or 0 (space) level of the transmit data. The frequencies are produced from the master clock oscillator using programmable dividers. The dividers respond quickly to data changes, introducing negligible bit jitter while maintaining phase coherence. The output of the FSK modulator is applied to the appropriate filter when the low speed mode of the operation is selected.

The filter section consists of low-band (1200 Hz) and high-band (2400 Hz) filters, half-channel compromise amplitude and group delay equalizers for both bands, smoothing filters for both bands and multiplexers for routing of the transmit and receive signals through the appropriate band filters . For CCITT V.22 applications, a notch filter is included that can be programmed for either 550 Hz or 1800 Hz. In the call progress monitor mode, the low-band filter is scaled down by a factor of 2.5 to center it over a frequency range of 300 to 660 Hz. Thus, during call establishment in the originate mode, call progress tones can be monitored through the scaled low-band filter and the modem answer tone or voice can be monitored through the unscaled highband filter.

The low-band filter is a 10th order switched-capacitor band-pass filter with a center frequency of 1200 Hz. In the originate mode, this filter is used in the transmit direction; in the answer mode it is used in the receive direction. When analog loopback is used in the originate mode, this filter, together with the lowband delay equalizer, is in the test loop. In the Call Progress Monitoring mode the filter response is scaled down by 2.5, moving the center frequency to 480 Hz.

The low-band delay equalizer is a 10th order switched-capacitor all-pass filter that compensates for the group delay variation of the low-band filter and half of the compromise line characteristics,



producing a flat delay response within the pass-band.

The high-band filter is a 10th order switched-capacitor band-pass filter with a center frequency of 2400 Hz. In the answer mode, this filter is used in the transmit direction; in the originate mode, it is used in the receive direction. When analog loopback is used in the answer mode, this filter, together with the highband delay equalizer, will be in the test loop.

The high-band delay equalizer is a 10th order switched-capacitor all-pass filter that compensates for the group delay variation of the high-band filter and half of the compromise line characteristics, producing a flat delay response within the pass-band. The transmit smoothing filter is a second order low-pass switched-capacitor filter that adds the modem transmit signal to the DTMF or V.22 guard tones. It also provides a 3dB per step programmable gain function to set the output level.

#### RECEIVER

The receiver section consists of an energy detector, AGC, PSK demodulator, FSK demodulator, descrambler, and sync/async converter.

The received signal is routed through the appropriate band-pass filter and applied to both the energy detector and AGC circuit. The energy detector is based on a peak detection algorithm. It provides a detection within 17 to 24 ms. It is set to turn on when the signal exceeds -43 dBm and turn off when the signal falls below -48 dBm. A 2 dB minimum hysteresis is provided between the turn on and turn off levels.

The AGC circuit is a programmable gain amplifier that covers a range of 28 dB in seven steps. The gain is controlled by a 3 bit up/down counter. Output of the AGC amplifier is rectified and compared with two preset levels corresponding to desired high and low limits. Outputs of the comparators control the up/down counter such that the received signal is amplified to the desired level.

The PSK demodulator uses a coherent demodulation technique. Output of the AGC amplifier is applied to a dual phase splitter that produces an in-phase and 90 degree out of phase component. These components are then demodulated to baseband in a mixer

stage where individual components are multiplied by the recovered carrier. The baseband components are low-pass filtered to produce I and Q channel outputs. (In-phase and Quadrature). The I and Q channel outputs are rectified, summed, and passed through a band-pass filter giving a 600 Hz signal. This signal is applied to a digital phase lock loop (DPLL) to produce a baud rate clock. Using the recovered clock signal, the I and Q channels are sampled to produce the received dibit data. The recovered carrier for the demodulator is generated by another PLL which is controlled by the amplitude of the error signal formed by the difference of the I and Q outputs.

The descrambler is similar to the scrambler. The received dibit data is applied to the D input of a 17 bit shift register clocked at 1200 Hz. Outputs from the 14th and 17th stages are exclusive OR'd and further exclusive OR'd with input data to produce received data.

In the asynchronous mode, data from the descrambler is applied to the sync/async converter to reconstruct the originally transmitted asynchronous data. For data which had stop bits deleted at the transmitter (overspeed data), these stop bits are reinserted. Underspeed data is passed essentially unchanged. Output of the sync/async converter along with the output of the FSK demodulator is applied to a multiplexer. The multiplexer selects the appropriate output, depending on the operating speed, and outputs received data on the RXD pin.

For low speed operation, the FSK demodulator is used. The output of the AGC amplifier is passed through a zero crossing detector and applied to a counter that is reset on zero crossings. The counter is designed to cycle at a rate four times faster than the carrier signal. The counter output is low-pass filtered and hard limited to generate FSK data.

#### HYBIRD

The signal on the phone line is the sum of the transmit and receive signals. The hybrid subtracts the transmitted signal from the signal on the line to form the received signal. It is important to match the hybrid impedance as closely as possible to the telephone line to produce only the received signal. This matching provided by an external resistor connected between the RXA1 and RXA2 pins on the VL7C212A. The filter section provides sufficient attenuation of the out of band signals to eliminate leftover transmit signals from the received signal. The hybrid also acts as a first order low-pass antialiasing filter.

#### TONE GENERATOR

The tone generator section consists of a DTMF generator and a V.22 guard tone generator. The DTMF generator produces all of the tones corresponding to digits 0 through 9 and \* and # keys. The V.22 guard tone generator produces either 550 Hz or 1800 Hz. Selection of either the 550 Hz or 1800 Hz tone will cascade the corresponding notch filter with the low-band filter. The tones are selected by applying appropriate codes through the Data I/O pin. Before a tone can be generated, tone mode must be selected. Facility is also provided to generate single tones corresponding to the individual rows or column of the DTMF signal.

#### AUDIO OUTPUT STAGE

A programmable attenuator that can drive a load impedance of 50 K ohms is provided to allow monitoring of the received line signal through an external speaker. The attenuator is connected to the output of the hybrid. Four levels of attenuation -- no attenuation, 6 dB attenuation, 12 dB attenuation and squelch are provided through the ALC1. ALC0 and audio output level control codes. Output of the attenuator is available on the audio output pin where an external audio amplifier (LM386 type) can be connected to drive a low impedance speaker. The output can directly drive a high impedance transducer, but the volume level will be low.

#### Functional Description: VL7C213 & VL7C214 Controllers

The VL7C213 modem controller, implemented in VTI's two micron CMOS process, was designed specifically to handle all of the modem control functions, as well as the interface to a system bus. Besides including an 8-bit microprocessor, 8K by 8 bytes of ROM, and 128 by 8 bytes of RAM, it also contains the functionality of a VL82C50 UART, greatly simplifying the interface to a parallel system bus, such as the one used in IBM's PC. In fact, a complete, Hayes compatible modem for the PC consists of the VL7C213 controller, the VL7C212A modem and the DAA. All of the popular communications software written for the PC will work with the VL7C212A/ VL7C213 set.

Another version of the controller, the VL7C214, is intended for RS-232 applications. It contains the same processor, memory, and UART as the VL7C213 and has the same interface to the modem chip. The difference is that the UART is turned around so that serial data from the RS-232 port is converted to parallel data handled by the internal processor. Pins are provided for connecting the familiar switches and indicator lamps found on most standalone modems, although the switches and lamps are not needed for operation -- all of the switch settings can be done through software.

The VL7C214 provides a standard five volt logic level interface -- RS-232 drivers are required to interface to the port. Like the VL7C213, the VL7C214 comes preprogrammed with the Hayes "AT" command set, and when used with the VL7C212A modem, emulates a Hayes-type stand-alone modem. The VL7C213 and VL7C212A emulate a Hayes-type IBM PC plug-in card modem.

But the chip set is by no means limited to implementing a Hayes-type smart modern. VTI is in the custom IC business and both chips were designed with this in mind. For example, only about 6K bytes of the VL7C213's ROM is used for the handshaking and smart modem code, leaving 2K bytes for additional features that a customer may specify. And since the controller is ROM programmable, any command set, not just the Hayes "AT" set, can be implemented.

Both the VL7C213 and VL7C214 require plus five volts and are available in either a 28 pin DIP or a 28 lead plastic chip carrier with "J" leads for surface mount applications. Besides the four-line interface for the VL7C212A modem, the VL7C213 controller has an 8-bit data port, three address lines, a chip select input, an interrupt line, and the DOST and DIST control lines found in the 8250B UART. It also has control lines for ring indication, the off-hook relay and a data/voice relay; these three lines connect to the DAA. In the VL7C214, the 8-bit port becomes the switch input lines and the address, chip select, DIST and DOST lines become the six lines for the RS-232 interface. These six lines are also used to drive the LEDs. Internally, all of these lines are treated as programmable I/O ports under software control -- so the main difference between the VL7C213 and VL7C214 is the ROM code. It also contains the same modem and DAA interface lines as the VL7C213.

The VL7C213 and VL7C214 are truly ASIC controllers -- they are designed to control a modem or other peripheral that operates at a moderately slow data rate up to 1200 bits per second. What's unique about the VL7C213, for example is that it allows a slow peripheral to interface to a high speed bus, without making the main processor slow down.

This is done through the UART interface and the on-chip registers which look somewhat like dual port registers. The main processor can write to and read from them at will, while the on-chip controller can do the same. The controller was designed this way because most communications software has to have unrestrained access to the UART registers. To make the VL7C213 compatible with this software, the registers were included.

The internal processor monitors the registers to determine the mode of operation -- command mode or data mode; at power-up it is automatically put in the command mode and it looks for instructions. Once carrier is detected, it goes into the data mode, and stays there until escape sequence is three + signs -- +++ -- in the default mode, but it can be changed in software.

The actual processor contains an 8-bit data path and can execute 19 instructions with five different addressing modes: direct, indirect, immediate, register direct, and register indirect. There is 8K by 8 of ROM onchip for program storage.

To the system bus, the VL7C213 looks and acts just like a VL82C50 UART. All of the communications software written for this UART will work with the VL7C213 and VL7C214. The VTI chip set is truly a Hayes-type modem in two chips.



# THE VL7C212A & VL7C213/VL7C214 SYSTEM

The only external components required by the VL7C212A are the 600 ohm line matching resistor, a 7.3728 MHz crystal -- a standard frequency -- and a 20 pf capacitor from each leg of the crystal to ground. That's all! If it is desired to drive a speaker to monitor the line, an amplifier like the LM386 can be added, but the output provided on the VL7C212A can directly drive a high impedance (50 K ohm) earphone-type transducer.

The VL7C213 modem controller's clock in line is driven by the VL7C212A's clock out line, so only one crystal is needed. The VL7C213 interfaces directly to an IBM PC bus -- no buffers are required. The only external parts may be an eight input NAND gate for COM1 and COM2 decoding inside the PC.

For tone dialing, the controller sends a code to the modem chip which in turns puts out the called for DTMF tone on the line via the on-chip DTMF generator. For pulse dialing, the controller pulses the OH (off-hook) relay. Both dialing modes work with the built-in call progress algorithm so they won't start dialing until a dial tone is detected.

All modems require a DAA. A DAA or data access arrangement is a piece of equipment required by the FCC to connect anything to the general switched telephone network. It consists of an isolation transformer, typically 600 ohms to 600 ohms: a relay for disconnecting the modern from the line; a ring detector, typically an optoisolator; and high voltage surge protectors. The DAA has to be FCC registered and this can be done by any of many consultants and labs around the country. The fee is typically \$2,000 and it takes several months. Another alternative is to buy a DAA, supplied by several manufacturers.

212A is a Bell specification that calls for 1200 bit per second, full or half duplex data transmission with a fallback mode of 300 baud (Bell 103). It is not 1200 baud; the spec calls for transmission of dibits -- 2 bits per baud so the 1200 bps transmission takes place at 600 baud. The same is true for V.22 -- it's 1200 bps or 600 baud. V.22 does not call for a 300 baud fallback; there is a CCITT standard for 300 and that's V.21. It is



not a required fallback for V.22 and it is not included in the VL7C212A.

V.22 also calls for guard tones to be sent along with the data. In most of Europe the tone is 1800 Hz except in Sweden where 550 Hz is used. The VL7C212A modem has the 550 Hz and 1800 Hz tone generators built in as well as the 550 and 1800 Hz notch filter to remove the guard tone when in the receive mode.

All modems require a hybrid. Hybrid is a term used to describe a circuit, passive or active, that takes the separate transmit and receive signals and

combines them to go over the phone line. In the VL7C212A, this is done with op amps, but the separate signals -- TXout and RXA2 -- are also brought out so an external hybrid can be used, if desired. The combined signal comes out on the RXA1 pin and a matching resistor -- typically 600 ohms -- is connected between RXA1 and RXA2.

| 14      | ТХД                                                                                                                                                      | PIN/FUNCTION<br>DESCRIPTIONS<br>Transmit data. Data on this input is modulated                                                                                                                     | 7        | Audio<br>Out                                                                            | Output of the hybrid is passed through a<br>programmable attenuator and brought out on<br>this pin. Four levels of received signal can be<br>programmed using the control codes listed in<br>Table 1. |  |  |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-----------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|         |                                                                                                                                                          | by the modem and output on TXout pin. A logic low is space and a logic high is mark.                                                                                                               | 20<br>21 | XTAL1<br>XTAL                                                                           | Pins for connecting a 7.3728 MHz crystal. An external clock signal can be applied to the                                                                                                              |  |  |
| 13      | RXD                                                                                                                                                      | Receive data. The modern demodulates the received carrier and outputs data on this pin. A                                                                                                          |          |                                                                                         | XTAL1 pin.                                                                                                                                                                                            |  |  |
|         | logic low level is space and a logic high level is<br>mark. The controller can force the demodulator<br>output to the mark state by sending the code 02. | 23                                                                                                                                                                                                 | CKOUT    | Buffered crystal oscillator signal is output on this pin. It can drive one LS TTL load. |                                                                                                                                                                                                       |  |  |
| 15      | D 1/0                                                                                                                                                    | Data I/O pin. Data is shifted in serially when WB                                                                                                                                                  | 2 T      | хско                                                                                    | Transmitter clock output. In high speed,<br>synchronous, internal mode, this output<br>supplies a 1200 Hz clock to the DTE.                                                                           |  |  |
|         |                                                                                                                                                          | is low on rising edges of SCK clock. Data is<br>transferred to a latch when WR goes high. Up to<br>seven data bits can be sent. Input codes are<br>defined in table 1. Data is read from the modem | 3 TXCK1  |                                                                                         | In high speed, synchronous external mode<br>this pin is an input for receiving a 1200 Hz<br>clock from the DTE.                                                                                       |  |  |
|         |                                                                                                                                                          | clock. Up to four data bits can be read. Output codes are defined in table 1.                                                                                                                      |          | ХСК                                                                                     | Receiver clock output. In high speed,<br>synchronous, external mode, the modem<br>supplies a 1200 Hz clock on this output.                                                                            |  |  |
| 18      | WR                                                                                                                                                       | Strobe output from the controller for shifting data to the modern.                                                                                                                                 | 24       | VCC                                                                                     | + 5V power supply.                                                                                                                                                                                    |  |  |
| 17      | RD                                                                                                                                                       | Strobe output from the controller for serially reading data from the modern.                                                                                                                       | 12       | VSS                                                                                     | - 5V power supply.                                                                                                                                                                                    |  |  |
| 16      | SCK                                                                                                                                                      | Serial shift clock is applied to this pin. It is                                                                                                                                                   | 22       | DGND                                                                                    | Digital ground.                                                                                                                                                                                       |  |  |
| IU SCK  | JUN                                                                                                                                                      | normally high until data is sent to, or read from,<br>the modem                                                                                                                                    |          | AGND                                                                                    | Analog ground.                                                                                                                                                                                        |  |  |
| 11      | TXout                                                                                                                                                    | Transmit data carrier output.                                                                                                                                                                      | 4<br>5   | TEST1<br>TEST2                                                                          | Used by VTI for testing. Make no connection to these pins they must be left floating.                                                                                                                 |  |  |
| 9<br>10 | RXA1<br>RXA2                                                                                                                                             | Received data carriers.                                                                                                                                                                            | 8<br>19  | NC<br>NC                                                                                | No connect. No internal connection is made to these pins and they may be left floating.                                                                                                               |  |  |

VL7C212A

#### TABLE 1. DEFINITION OF I/O CODES

1. Instructions to the modem IC

Data on the D I/O pin is shifted into the modem when WR is low, on rising edges of the SCK clock. Data is transferred into a latch when WR goes high. (See Figure 2 for write cycle waveforms.) Up to seven data bits (D0--D6) can be sent to the device. These bits control the operating modes of the modem as show below:

| D6                                                                                          | D5                                                                 | D4                                                                                          | D3D0                                                                         | Mode/Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------------------------------------------------------------------------------------------|--------------------------------------------------------------------|---------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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 | 1/0<br>1/0<br>1/0<br>1/0<br>1/0<br>1/0<br>1/0<br>1/0<br>1/0<br>1/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 | 0 1 2 3 4 5 6 7 8 9 A B C D E F 0 1 2 3 4 5 6 7                              | Non Tone Mode:<br>Reset (set default values)<br>Tone On/Off<br>Force Receive Data to Mark Off/On<br>TLC0 Transmit Level Control Bit 0 (default 0)<br>TLC1 Transmit Level Control Bit 1 (default 0)<br>TX Transmitter On/Off<br>ALB Analog Loopback On/Off<br>CPM Call Progress Monitor Mode On/Off<br>Connection Indicator (CI) On/Off<br>ALCO Audio Output Level Control Bit 0 (default 0)<br>ALC1 Audio Output Level Control Bit 1 (default 0)<br>WLS1 Word Length Select 0 (default 1)<br>Sync/Async<br>LS/HS: Low Speed/High Speed<br>A/0: Answer/Originate<br>Transmit Mark On/Off<br>Scrambler Disable On/Off<br>DLB Digital Loopback On/Off<br>TXDP Transmit Dotting Pattern On/Off<br>Locked/Internal<br>External/Slave<br>V.22 2100 Hz Tone On/Off. Must select low speed of<br>mode for operation |
| 1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1                     | 1/0<br>1/0<br>1/0<br>1/0<br>1/0<br>1/0<br>1/0<br>1/0<br>1/0<br>1/0 |                                                                                             | 0<br>1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>A<br>B<br>C<br>D<br>E<br>F | Tone Mode:<br>Dial 0<br>Dial 1<br>Dial 2<br>Dial 3<br>Dial 4<br>Dial 5<br>Dial 4<br>Dial 5<br>Dial 6<br>Dial 7<br>Dial 8<br>Dial 9<br>Dial *<br>Dial #<br>Output 550 Hz and Insert 550 Hz Notch in Low-Band<br>Filter<br>Output 1800 Hz and Insert 1800 Hz Notch inLow-Band<br>Filter<br>Row Disable On/Off<br>Column Disable On/Off                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |



## TABLE 1. DEFINITION OF I/O CODES (continued)

| WLS1 | WLS0             |        |             |        |       |       |                  | Wo                   | rd           | Ler                                    | ngth                             |
|------|------------------|--------|-------------|--------|-------|-------|------------------|----------------------|--------------|----------------------------------------|----------------------------------|
| 0    | 0                | 9 Bits |             |        |       |       |                  |                      | 8            |                                        | Bite                             |
| U    | 0                | 3 013  |             |        |       | 10    |                  | Bits<br>11           |              | (defa                                  | aul <b>t)</b><br>Bit <b>s</b>    |
| TLC1 | TLC0             |        | Transmitter | Output | Level | (dBm) | at               | the                  | Pho          | one l                                  | Line                             |
|      | 0<br>1<br>0<br>1 |        |             |        |       |       |                  | -                    | -12          | (defa                                  | ault)<br>9<br>6<br>0             |
| ALC1 | ALC0             |        |             |        |       | Au    | udio             | Out                  | tput         | L                                      | evel                             |
|      | 0<br>1<br>0<br>1 |        |             |        |       | C     | utput<br>12<br>6 | Of<br>dB<br>dB<br>No | ff<br>A<br>A | (defa<br>Attenua<br>Attenua<br>Attenua | ault)<br>atiot<br>atiot<br>atiot |

2. Information from the Modem IC

Data is read serially from the modem when RD is low, on rising edges of the SCK clock. (See Figure 1 for read cycle waveforms.) Up to four data bits (D0--D3) can be read as defined below:

| D0 | Energy Detect | 0 - No Energy 1 | - 1 | Energy | Present |
|----|---------------|-----------------|-----|--------|---------|
|    |               |                 |     |        |         |

In the CPM mode, the energy detector is connected to the output of the high band filter, if ALB is off, or the scaled lowband filter, if ALB is on.

| D1 | Received Data (FSK) | 1 | - | Mark         |   |   | 0   | - Space  |
|----|---------------------|---|---|--------------|---|---|-----|----------|
| D2 | Received Data (PSK) | 1 | - | Mark         |   |   | 0   | - Space  |
| D3 | Unscrambled Mark    |   |   | 1 - Detected | 0 | - | Not | Detected |

Notes:

1) Default values for the operating modes on power up are those shown to the right of the "/" unless otherwise specified.

2) Data is shifted in and out of the modem with LSB first.

## VL80C75 PRODUCT BRIEF



## T1 INTERFACE

#### FEATURES

- Supports T1, T1C and CEPT data rates
- AMI, B8ZS, HDB3 coding
- Full implementation of CCITT recommendations G.703, G.732, G.733 & Bell Technical Advisories on clear channel and extended framing format
- Compatible with:
  - MTEL TDMA 10xx
  - SDSI
  - LITEL TAS
  - T1 Video Teleconference Equipment
- On-chip voltage comparators and AGC
- Input frequency memory
- Jitter smoothing FIFO
- Loop control feedback
- · Error detection & flagging
- Self test provision
- Microprocessor compatible interface
- Low power CMOS technology

### **PIN DIAGRAM**



## DESCRIPTION

The VL80C75 is a general purpose PCM Line Interface circuit. It is designed to support the bipolar interface of T1 (1.544 Mbps), T1C (3.152M bps), or CEPT (2.048 Mbps) specifications. It is capable of sending (coding) and receiving (decoding) AMI, B8ZS or HDB3 data formats with appropriate error correction.

The incorporation of on-chip voltage reference levels and comparators, allow the device decoder section to accept incoming ternary/bipolar data directly. Sensitivity is optimized by monitoring the level and waveform of the incoming bipolar signal.

An injection locking divider permits clock recovery from the incoming serial data stream. A 32-bit long FIFO (elastic buffer) may be used in either the decoder or the encoder path to smooth clock jitter. Status information is provided to facilitate the control of an external VCO.

The VL80C75 will indicate the presence of bipolar violation in the input data as well as a FIFO underflow/overflow.

Interfacing to the external bipolar line output circuits is facilitated by the provision of 50% duty cycle drive pulses. The system interface is microprocessor compatible. The T1 Interface internal registers may be accessed by either a serial or parallel interface.

System test is assisted by the provision of a loopback feature which operates in both directions.

The VL80C75 is fabricated in a double metal, n well, 2 micron silicon gate CMOS process and is housed in a 28 pin DIP or ceramic package.

### BLOCK DIAGRAM



#### **ORDER INFORMATION**

| Part<br>Number | Package     |
|----------------|-------------|
| VL80C75 - PC   | Plastic DIP |
| VL80C75 - CC   | Ceramic DIP |



| SECTION 8<br>SALES OFFICES,<br>DESIGN CENTERS,<br>AND<br>DISTRIBUTORS |
|-----------------------------------------------------------------------|
|                                                                       |
|                                                                       |
|                                                                       |
|                                                                       |
| <br>_                                                                 |
|                                                                       |
|                                                                       |
| <br>                                                                  |

Application Specific Logic Products Division



#### VI SI OFFICES

CORPORATE HEADQUARTERS • VLSI Technology, Inc. • 1109 McKay Drive • San Jose, CA 95131 • 408-434-3100 APPLICATION SPECIFIC LOGIC AND GOVERNMENT PRODUCTS • VLSI Technology, Inc. • 10220 South 51st Street Phoenix, AZ 85044 • 602-893-8574/VLS

#### VLSI SALES OFFICES AND DESIGN CENTERS

BOSTON 261 Ballardvale St Wilmington, MA 01887 617-658-9501/9502 FAX 617-657-6420 CHICAGO CRICAGO 1350 Remington Rd., Stes. A-B Schaumburg, IL 60195 312-310-9595 FAX 312-310-9632

DALLAS 850 E. Arapaho Rd., Ste. 270 850 E. Arapano Rd., 5 Richardson, TX 75081 214-231-6716 FAX 214-669-1413 PRINCETÓN 101 Morgan Lane, Ste. 380 Plainsboro, NJ 08536 609-799-5700 FAX 609-799-5720

#### VLSI SALES OFFICES

ATLANTA 3020 Holcomb Bridge Rd., Ste. 110 Norcross, GA 3007 404-446-1326 BALTIMORE BALTIMORE P.O. Box 289 124 Maryland, Rte. 3 N Millersville, MD 21108 301-987-8777 FORT LAUDERDALE 2200 Park Central N., Ste, 600 Pompano Beach, FL 33064 305-971-0404 FAX 305-971-2086

LOS ANGELES 225 W. Broadway, Ste. 500 Glendale, CA 91204 818-995-2404 MINNEAPOLIS MINNEAPOLIS 5871 Cedar Lake Rd., Ste. 9 St. Louis Park, MN 55416 612-545-1490 PHILADELPHIA 5 Great Valley Pkwy., Ste. 221 Malvern, PA 19335 215-648-3946

CONNECTICUT

#### PHOENIX PHOENIX 10220 S. 51st St. Phoenix, AZ 85044 602-893-8574 FAX 602-893-0896 PORTLAND 10300 S.W. Greenbu Portland, OR 97223 503-244-9882 burg Rd., Ste. 470 FAX 503-244-9880 ТАМРА 1345 S. Missouri Ave., Ste. 205 Clearwater, FL 33516 813-443-5797

SAN JOSE 2235 Qume Dr. San Jose, CA 95131 408-434-3000 FAX 408-263-2511

TELEX 278807 MAIL 1109 McKay Dr

San lose CA 95131

SANTA ANA 1751 E. Garry Ave., Ste. A Santa Ana, CA 92705 714-250-4900 FAX 714-250-9041

EUROPE

ENGLAND

Midsummer House Midsummer Blvd.

FAX 44-908-670027

Midsummer Brod. Central Milton Keynes, MK9 3BN England 44-908-667595 TELEX 825135 VLSI UK G

#### EUROPE GERMANY Rosenkavalierplatz 10 D-8000 Munich 81

D-8000 Munich 81 West Germany 49-89-926905-0 TELEX 521 4279-VLSI D FAX 49-89-92690545

FRANCE 
 FHANCE
 2.
 Allee du 10, Rue Ambroise Croizai
 91120 Palaiseau-France
 33-1-64470479
 TELEX 600759F
 FAX 33-1-644704870

#### VLSI SALES REPRESENTATIVES

#### ALABAMA

ELECTRONIC MFGS'. AGENTS Huntsville, 205-830-4030 TWX 810-726-2110 ARIZONA

SYSTEM SALES Tempe, 602-829-9338 TELEX 296966 FAX 602-966-1654

CALIFORNIA BESTRONICS San Diego, 619-693-1111 JONES AND MCGEOY SALES Santa Ana, 714-547-6466 TELEX 62931369 EMERGING TECHNOLOGY Santa Clara, 408-727-1771 TELEX 757199 EMERGING TECHNOLOGY Orangevale, 916-961-894 COLOBADO LUSCOMBE ENGINEERING Boulder, 303-772-3342

NEW ENGLAND TECH. SALES Meriden, 203-237-8827 GEORGIA ELECTRONIC MFGS'. AGENTS Roswell, 404-992-7240 ILLINOIS PHASE II MARKETING Schaumburg, 312-303-5092 MARYLAND ADVANCED TECH. SALES Linthicum, 301-789-9360 MICHIGAN LEADING EDGE SALES Plymouth, 313-420-3344 NEW MEXICO SYSTEM SALES OF ARIZONA Albuquerque, 505-242-7998 FAX 505-242-8096

NEW YORK L-MAR ASSOC. Ithica, 607-257-5712 L-MAR ASSOC. Rochester, 716-323-1000 TWX 510-253-0942 L-MAR ASSOC. E. Syracuse, 315-437-7779 TRI-TEK ASSOCIATES New Hyde Park, 516-747-8851 NORTH CAROLINA ELECTRONIC MFGS'. AGENTS Charlotte, 704-365-0547 ELECTRONIC MFGS', AGENTS h, 919-846-689 оню SAI MARKETING CORP. ous, 614-876-8 SAI MARKETING CORP Dayton, 513-435-318 FAX 513-435-3760

SAI MARKETING CORP. Shaker Heights, 216-751-3633 TWX 810-421-8289

OKLAHOMA LOGIC 1 SALES Tulsa, 918-494-0765 OREGON

MICRO SALES Aloha, 503-642-1818 TWX 910-464-5133 PENNSYI VANIA

OMNI SALES Erdenhein, 215-233-4600 TWX 510-661-9170 TEXAS LOGIC 1 SALES Austin, 512-459-1297 TWX 910-874-1395 FAX 512-459-1712 LOGIC 1 SALES ton 713-981-0233

LOGIC 1 SALES Richardson, 214-234-0765 FAX 214-669-3042 TELEX 510-600-8285 LOGIC 1 SALES Fort Worth 817-336-2192 WASHINGTON MICRO SALES Bellevue, 206-451-0568 WISCONSIN PHASE II MARKETING Wisconsin, 414-272-1171 CANADA bbd ELECTRONICS, INC. Mississauga, Ontario 416-821-7800 TELEX 06-218523

LOGIC 1 SALES

bbd ELECTRONICS, INC. Ottawa Ontario 613-729-0023 **bbd ELECTRONICS INC** Pointe Claire, Que 514-697-0804

#### ARROW ELECTRONICS, INC. ARROW INT'L. TWX 510-224-6021 GEORGIA

ALABAMA Huntsville, 205-837-6955 ARIZONA Phoenix 602-968-4800 CALIFORNIA CALIFORNIA Los Angeles, 818-701-7500 Orange County, 714-838-5422 San Diego, 619-565-4800 San Francisco, 415-745-6600 COLORADO Denver, 303-696-1111 CONNECTICUT Wallingford, 203-265-774 FLORIDA Clearwater, 813-576-8995 Fort Lauderdale, 305-429-8200 Melbourne, 305-725-1480

Atlanta 404-449-8252 ILLINOIS Chicago, 312-397-3440 INDIANA Indianapolis, 317-243-9353 IOWA Cedar Rapids, 319-395-7230 MARYLAND Baltimore, 301-995-0003 MASSACHUSETTS Boston, 617-933-8130 MICHIGAN MICHIGAN Detroit, 313-971-8220 Grand Rapids, 616-243-0912 MINNESOTA Minneapolis, 612-830-1800

MISSOURI St. Louis, 314-567-6888 NEW HAMPSHIRE Manchester, 603-668-6968 NEW JERSEY Fairfield, 201-575-5300 Marlton, 609-596-8000 NEW MEXICO Albuquerque, 505-243-4566 NEW YORK NEW YORK Long Island, 516-231-1000 Rochester, 716-427-0300 Syracuse, 315-652-1000 NORTH CAROLINA Raleigh, 919-876-3132 Winston-Salem, 919-725-8711

оню Cleveland, 216-248-3990 Columbus, 614-885-8362 Dayton, 513-435-5563 OKLAHOMA Tulsa, 918-665-7700 OREGON Portland, 503-684-1690 PENNSYLVANIA Philadelphia, 215-928-1800 Pittsburgh, 412-856-7000 RHODE ISLAND East Providence, 401-431-0980 TEXAS Austin, 512-835-4180 Dallas, 214-380-6464 Houston, 713-530-4700

UTAH Salt Lake City, 801-972-0404 WASHINGTON Seattle, 206-643-4800 WISCONSIN Milwaukee, 414-792-0150

PUERTO RICO San Juan, 809-723-6500 CANADA Montreal, 514-735-5511 Ottawa, 613-226-6903 Quebec City, 418-687-4231 Toronto, 416-661-0220

The information contained in this document has been carefully checked and is believed to be reliable: however, VLSI shall not be responsible for any loss or damage of whatever nature resulting from the use of, or reliance upon, the information contained in this document. VLSI makes no guarantee or warranty concerning the accuracy of such information,

and this document does not in any way extend VLSI's warranty on any product beyond that set forth in VLSI's standard terms and conditions of sale. VLSI does not guarantee that the use of any information contained herein will not infringe upon the patent or other rights of third parties, and no patent or other license is implied hereby. VLSI

reserves the right to make changes in the product without notification which would render the information contained in this document obsolete or inaccurate. Please contact VLSI for the latest information concerning this product © 1986 VLSI Technology, Inc. Printed in U.S.A.



VLSI Technology, Inc. Application Specific Logic Products Division 10220 South 51st Street Phoenix, AZ 85044 602-893-8574/VLSI