# INTEGRATED CIRCUITS







# PSD3XX Programmable Microcontroller Peripherals

# **Philips Semiconductors**





Philips Semiconductors and North American Philips Corporation reserve the right to make changes, without notice, in the products, including circuits, standard cells, and/or software, described or contained herein in order to improve design and/or performance. Philips Semiconductors assumes no responsibility or liability for the use of any of these products, conveys no license or title under any patent, copyright, or mask work right to these products, and makes no representations or warranties that these products are free from patent, copyright, or mask work right infringement, unless otherwise specified. Applications that are described herein for any of these products are for illustrative purposes only. Philips Semiconductors makes no representation or warranty that such applications will be suitable for the specified use without further testing or modification.

#### LIFE SUPPORT APPLICATIONS

Philips Semiconductors and North American Philips Corporation Products are not designed for use in life support appliances, devices, or systems where malfunction of a Philips Semiconductors and North American Philips Corporation Product can reasonably be expected to result in a personal injury. Philips Semiconductors and North American Philips Corporation customers using or selling Philips Semiconductors and North American Philips Corporation Products for use in such applications do so at their own risk and agree to fully indemnify Philips Semiconductors and North American Philips Corporation products for use or sale.

© Copyright North American Philips Corporation, 1993

# Preface

#### PSD3XX Programmable Microcontroller Peripherals

#### PSDX3XX Programmable Microcontroller Peripherals from Philips Semiconductors

Philips Semiconductors supplies a wide range of microcontrollers peripherals for use with all of the popular microcontroller architectures. By offering a wide range of peripheral products, we can meet a broad range of specific or unique application requirements. In addition, Philips Semiconductors supplies a full line of microcontrollers based on the 80C49 and 80C51 architectures. With over 50 derivatives of the 80C51 microcontroller available, Philips Semiconductors has the broadest offering on the market.

This data handbook covers the PSD3XX products. These programmable microcontroller peripherals contain 32K to 128K bytes of EPROM (UV erasable or One Time Programmable) external program memory, 2K bytes of SRAM external data memory, and memory paging and port reconstruction logic. Philips Semiconductors' PSD3XX products interface directly to our 80C51 microcontrollers without need of any other parts. This allows the memory of the microcontroller to be increased with the addition of only one part and without the loss of the functionality of the microcontroller ports used in the interface.

Philips Semiconductors supplies a wide range of microcontrollers based on mainstream architectures, spanning 8-, 16-, and 32-bit product lines. All of our microcontrollers are based on mainstream architectures to allow our customers to take advantage of existing software and a vast array of third-party support.

Philips Semiconductors' 8-bit microcontrollers are based on the popular 80C51 and 80C49 architectures. We offer most of the Industry Standard products as well as a large selection of powerful derivatives. Many of the derivatives have an I<sup>2</sup>C serial interface that allows them to be easily connected to over 70 other parts: this increases their capabilities even further. The 80C51 products are covered in the *80C51-Based 8-Bit Microcontrollers* data handbook (IC20) and the I<sup>2</sup>C parts that are most commonly used with microcontrollers are covered in the *1<sup>2</sup>C* Peripherals for Microcontrollers data handbook. Philips Semiconductors offers the most 80C51 derivatives in the world.

Philips Semiconductors' 16-bit microcontroller family is based on the powerful 68000 architecture. While these are called 16-bit microcontrollers, the 68000 CPU core architecture is 32-bit. This offers the user a great deal more processing power, when the need arises in a design to move from an 8-bit to a 16-bit microcontroller. Philips Semiconductors' 16-bit microcontrollers are software compatible with existing 68000 code. As with our popular 8-bit microcontrollers, EPROM and OTP versions of our 16-bit products are available. The 16-bit microcontrollers are covered in a separate data handbook, the IC21, 68000-Based 16-bit Microcontrollers.

Philips Semiconductors is developing a family of 32-bit microcontrollers based on the SPARC RISC architecture. This family of microcontrollers will offer the ultimate in processing power for those applications that are computation-intensive in a embedded control environment.

Philips Semiconductors offers uncompromising quality, service, and support with all of our microcontroller and microcontroller peripheral products. For a complete family and the best in microcontroller products, look to Philips Semiconductors.

Philips Semiconductors - Microcontroller Products

# **Product Status**

#### PSD3XX Programmable Microcontroller Peripherals

| DEFINITIONS                                            |                        |                                                                                                                                                                                                                                                                     |  |  |
|--------------------------------------------------------|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Data Sheet Product Status Definition<br>Identification |                        |                                                                                                                                                                                                                                                                     |  |  |
| <b>Objective Specification</b>                         | Formative or in Design | This data sheet contains the design target or goal specifications for<br>product development. Specifications may change in any manner<br>without notice.                                                                                                            |  |  |
| Preliminary Specification                              | Preproduction Product  | This data sheet contains preliminary data, and supplementary data<br>will be published at a later date. Philips Semiconductors reserves the<br>right to make changes at any time without notice in order to improve<br>design and supply the best possible product. |  |  |
| Product Specification                                  | Full Production        | This data sheet contains Final Specifications. Philips Semiconductors<br>reserves the right to make changes at any time without notice, in order<br>to improve design and supply the best possible product.                                                         |  |  |

#### **Ordering Information**

#### PART NUMBER EXPLANATION



# Contents

PSD3XX Programmable Microcontroller Peripherals

| Preface                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | iii                                     |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|
| Product Status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | iv                                      |
| Ordering Information                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | v                                       |
| · · · · · · · · · · · · · · · · · · ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 3<br>33<br>55<br>73<br>95<br>113<br>133 |
| Section 2       PSD3XXL Family         PSD3XXL Family 3-volt single-chip microcontroller peripherals       PSD301 <sup>®</sup> L 3-volt single-chip microcontroller peripheral (x8/x16; 256Kb EPROM, 16Kb SRAM)         PSD311L 3-volt single-chip microcontroller peripheral (x8; 256Kb EPROM, 16Kb SRAM)       PSD301 <sup>®</sup> L 3-volt single-chip microcontroller peripheral (x8/x16; 512Kb EPROM, 16Kb SRAM)         PSD302L 3-volt single-chip microcontroller peripheral (x8/x16; 512Kb EPROM, 16Kb SRAM)       PSD3012L 3-volt single-chip microcontroller peripheral (x8/x16; 512Kb EPROM, 16Kb SRAM)         PSD303L 3-volt single-chip microcontroller peripheral (x8/x16; 10Mb EPROM, 16Kb SRAM)       PSD303L 3-volt single-chip microcontroller peripheral (x8/x16; 10Mb EPROM, 16Kb SRAM)         PSD313L 3-volt single-chip microcontroller peripheral (x8/x16; 10Mb EPROM, 16Kb SRAM)       PSD313L 3-volt single-chip microcontroller peripheral (x8/x16; 10Mb EPROM, 16Kb SRAM) | 181<br>203<br>221<br>243                |
| Section 3       Application Notes         Application Note 011 The PSD3XX Device Description       2         Application Note 013 The PSD301 Streamlines a Microcontroller-Based Smart Transmitter Design       2         Application Note 013 The PSD3XX PAD for System Logic Replacement       2         Application Note 015 Using Memory Paging with the PSD3XX       2         Application Note 016 Power Considerations in the PSD3XX       2         Application Note 018 Security of Design in the PSD3XX       2         Application Note 019 The PSD311 Simplifies an Eight Wire Cable Tester Design and Increases Flexibility       2         Application Note 020 Benefits of 16-Bit Design with PSD3XX       2                                                                                                                                                                                                                                                                            | 357<br>371<br>385<br>399<br>413<br>417  |
| Section 4         Developing Systems           PSD Gold/PSD Silver Development System         4           WS6000 MagicPro® Memory and Programmable Peripheral Programmer         4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                         |
| Section 5       Package Outlines         J2 44-Pin Plastic Leaded Chip Carrier (PLCC)       4         L4 44-Pin Ceramic Leaded Chip Carrier (CLCC) with Window (Package Type L)       4         Q2 52-Pin Plastic Quad Flatpack (PQFP)       4         Section 6       Sales Offices, Representatives & Distributors                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 462<br>463                              |

PSD301 is a registered trademark of WaferScale Integration, Inc. MagicPro is a registered trademark of WaferScale Integration, Inc.

# Section 1 PSD3XX Family

PSD3XX Programmable Microcontroller Peripherals

#### INDEX

| PSD3XX<br>Family    | Field-programmable microcontroller peripherals                                         |
|---------------------|----------------------------------------------------------------------------------------|
| PSD301 <sup>®</sup> | Field-programmable<br>microcontroller peripheral<br>(x8/x16; 256Kb EPROM, 16Kb SRAM)   |
| PSD311              | Field-programmable<br>microcontroller peripheral<br>(x8; 256Kb EPROM, 16Kb SRAM)55     |
| PSD302              | Field-programmable<br>microcontroller peripheral<br>(x8/x16; 512Kb EPROM, 16Kb SRAM)73 |
| PSD312              | Field-programmable<br>microcontroller peripheral<br>(x8; 512Kb EPROM, 16Kb SRAM)95     |
| PSD303              | Field-programmable<br>microcontroller peripheral<br>(x8/x16; 1Mb EPROM, 16Kb SRAM)113  |
| PSD313              | Field-programmable<br>microcontroller peripheral<br>(x8; 1Mb EPROM, 16Kb SRAM)133      |

#### **Key Features**

- □ Single Chip Programmable Peripheral for Microcontroller-based Applications
- 19 Individually Configurable I/O pins that can be used as
- Microcontroller I/O port expansion
- Programmable Address Decoder (PAD) I/O
- Latched address output
- Open drain or CMOS
- Two Programmable Arrays (PAD A and PAD B)
- Total of 40 Product Terms and up to 16 Inputs and 24 Outputs
- Address Decoding up to 1 MB
- Logic replacement
- "No Glue" Microcontroller Chip-Set
- Built-in address latches for multiplexed address/data bus
- Non-multiplexed address/data bus mode
- ALE and Reset polarity programmable
- Selectable modes for read and write control bus as RD/WR or R/W/E
- 256 Kbits of UV EPROM
- Configurable as 32K x 8 or as 16K x 16
- Divides into 8 equal mappable blocks for optimized mapping

- Block resolution is 4K x 8 or 2K x 16
- 120 ns EPROM access time, including input latches and PAD address decoding.
- 16 Kbit Static RAM
- Configurable as 2K x 8 or as 1K x 16
- 120 ns SRAM access time, including input latches and PAD address decodina
- Address/Data Track Mode
- Enables easy Interface to Shared Resources (Mail Box SRAM) with other Microcontrollers or a Host Processor
- Built-In Security
- Locks the PSD3XX Configuration and PAD Decoding
- Available in a Variety of Packaging
- 44 Pin PLDCC and CLDCC
- Simple Menu-Driven Software: Configure the PSD3XX on an IBM PC

| <i>PSD3XX<br/>Family<br/>Feature<br/>Summary</i> | Part                | PLD<br>Inputs/<br>Product<br>Terms | Ports | EPROM<br>Size | SRAM<br>Size | Configuration | Memory<br>Paging | C-Miser<br>Bit | Security<br>Bit |
|--------------------------------------------------|---------------------|------------------------------------|-------|---------------|--------------|---------------|------------------|----------------|-----------------|
|                                                  | PSD301 <sup>®</sup> | 14/40                              | 19    | 256 Kb        | 16 Kb        | x8 or x16     |                  | X              | х               |
|                                                  | PSD311              | 14/40                              | 19    | 256 Kb        | 16 Kb        | x8            |                  | х              | х               |
|                                                  | PSD302              | 18/40                              | 19    | 512 Kb        | 16 Kb        | x8 or x16     | x                | х              | х               |
|                                                  | PSD312              | 18/40                              | 19    | 512 Kb        | 16 Kb        | x8            | х                | х              | x               |
|                                                  | PSD303              | 18/40                              | 19    | 1 Mb          | 16 Kb        | x8 or x16     | х                | х              | х               |
|                                                  | PSD313              | 18/40                              | 19    | 1 Mb          | 16 Kb        | x8            | X                | x              | х               |

3

#### Preliminary specification

| Field-program                                          | nable microcontroller peripherals                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | PSD3XX Family                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|--------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Partial Listing<br>of<br>Microcontrollers<br>Supported | <ul> <li>Motorola family:<br/>M6805, M68HC11, M68HC16,<br/>M68000/10/20, M60008, M683XX</li> <li>Intel family:<br/>8031/8051, 8096/8098, 80186/88,<br/>80196/98</li> <li>Signetics:<br/>SC80C451, SC80552</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                       | <ul> <li>TI:<br/>SC80C451, TMS320C14</li> <li>Zilog:<br/>Z8, Z80, Z180</li> <li>National:<br/>HPC16000, HPC46400</li> </ul>                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| Applications                                           | <ul> <li>Computers (Notebook and Portable PCs)</li> <li>Fixed Disk Control, Modem, Imaging,<br/>Laser Printer Control</li> <li>Telecommunications</li> <li>Modem, Cellular Phone, Digital PBX,<br/>Digital Speech, FAX,<br/>Digital Signal Processing</li> </ul>                                                                                                                                                                                                                                                                                                                                                           | <ul> <li>Portable Industrial Equipment</li> <li>Measurement Meters, Data Recorders</li> <li>Medical Instrumentation</li> <li>Hearing Aids, Monitoring Equipment,<br/>Diagnostic Tools</li> </ul>                                                                                                                                                                                                                                                                                                          |  |  |
| Introduction                                           | The PSD3XX Series are members of the<br>rapidly growing family of PSD devices. They<br>are the market's first low-voltage single-chip<br>solution for microcontroller-based<br>applications where consistent specifications<br>for design, fast time-to-market, small form<br>factor, and low power consumptions are<br>essential. When combined in an 8- or 16-bit<br>system, virtually any microcontroller<br>(68HC11, 8051, 80186, etc.) and the<br>PSD3XX device work together to create a<br>very powerful chip-set solution. This<br>implementation eliminates mixing and<br>matching low voltage specifications for | various discrete components. It also<br>provides all the required control and<br>peripheral elements needed in a<br>microcontroller-based system with no<br>external discrete "glue" logic required.<br>The solution comes complete with simple<br>system software development tools for<br>integrating the PSD3XX with the<br>microcontroller. Hosted on IBM PC<br>platforms or compatibles, the easy to use<br>software enables the designer to quickly<br>configure the device and use it immediately. |  |  |

PSD301 is a registered trademark of WaterScale Integration, Inc. PAL is a registered trademark of Advanced Micro Devices, Inc.

#### PSD3XX Family

#### Product Description

The PSD3XX family integrates high performance user-configurable blocks of EPROM, SRAM, and programmable logic. The major functional blocks include two programmable logic arrays, PAD A and PAD B, 256K to 1Mbit of EPROM, 16K bits of SRAM, input latches, and output ports. The PSD3XX family is ideal for applications requiring low power and very small form factors. These include hard disk control, modems, cellular telephones, instrumentation, computer peripherals, military and similar applications.

The PSD3XX family offers a unique singlechip solution for microcontrollers that need:

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

The PSD3XX Family Architecture (Figure 1) can efficiently interface with, and enhance, any low-voltage 8- or 16-bit microcontroller system. This is the first solution that provides microcontrollers with port expansion, latched addresses, page logic, two programmable logic arrays (PAD A and PAD B), an interface to shared resources, 256K, 512K or 1M bit EPROM, and 16K bit SRAM on a single chip. The PSD3XX family does not require any glue logic for interfacing to any 8- or 16-bit microcontroller. The 8051 microcontroller family can take full advantage of the PSD3XX's separate program and data address spaces. Users of the 68HCXX microcontroller family can change the functionality of the control signals and directly connect the R/W and E, or the R/W and DS signals. (Users of 16-bit microcontrollers, including the 80186, 8096, 80196 and 16XXX, can use the PSD301/302/303 in a 16-bit configuration). Address and data buses can be configured as separate or multiplexed, whichever is required by the host processor.

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

The page register extends the accessible address space of certain microcontrollers from 64 K to 1 M. There are 16 pages that can serve as base address inputs to the PAD, thereby enlarging the address space of 16 address line microcontrollers by a factor of 16.



#### Field-programmable microcontroller peripherals

#### **PSD3XX** Family

| Table 1.<br>PSD3XX Pin         | Name                                            | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------------------------|-------------------------------------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Descriptions                   | BHE/PSEN<br>(PSD30X<br>Devices)                 |      | When the data bus width is 8 bits (CDATA = 0), this pin is $\overrightarrow{PSEN}$ . In this mode, $\overrightarrow{PSEN}$ is the active low EPROM read pulse. The SRAM and <u>I/O</u> ports read signal is generated according to the description of the WR/V <sub>PP</sub> or R/W and $\overrightarrow{RD/E/DS}$ pins. If the host processor is a member of the 8031 family, $\overrightarrow{PSEN}$ must be connected to the corresponding host pin. In other 8-bit host processors that do not have a special EPROM-only read strobe, $\overrightarrow{PSEN}$ should be tied to V <sub>CC</sub> . In this case, $\overrightarrow{RD}$ or E and $\overrightarrow{R/W}$ provide the read strobe for the SRAM, I/O ports, and EPROM. When the data bus width is configured as 16 (CDATA = 1), this pin is $\overrightarrow{BHE}$ . When $\overrightarrow{BHE}$ is low, data bus bits D8–D15 are read from, or written into, the $\overrightarrow{PSD3XX}$ , depending on the operation being read or write, respectively. In programming mode, this pin is pulsed between V <sub>PP</sub> and 0. |
|                                | or<br>PSEN<br>(PSD31X<br>Devices<br>Only)       | 1    | The $\overrightarrow{PSEN}$ is the active low EPROM read pulse. The SRAM and I/O<br>ports read signal is generated according to the description of the<br>WR/V <sub>PP</sub> or R/W, and <u>RD</u> /E pins. If the host processor is a member<br>of the 8031 family, PSEN must be connected to the correspondinbg<br>host pin. In other 8-bit host processors that do not have a special<br>EPROM-only read strobe, PSEN should be tied to V <sub>CC</sub> . In this case,<br>RD or E and R/W provide the read strobe for the SRAM, I/O ports,<br>and EPROM.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| or<br>R/W/V<br>RD/E/I<br>(Note | WR/V <sub>PP</sub><br>or<br>R/W/V <sub>PP</sub> | I    | In the operating mode this pin's function is $\overline{WR}$ (CRRWR = 0) or<br>R/W (CRRWR = 1) when configured as R/W. The following tables<br>summarize the read and write operations (CRRWR = 1):<br>$\begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                | RD/E/DS<br>(Note 2)                             | I    | The pin function depends on the CRRWR and CEDS configuration<br>bits. If CRRWR = 0, $\overline{RD}$ is an active low read pulse. When<br>CRRWR = 1, this pin and the R/W pin define the following cycle type:<br>If CEDS = 0, E is an active high strobe. If CEDS = 1, $\overline{DS}$ is an active<br>low strobe.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                | OF<br>RD/E<br>(Note 3)                          | I    | When configured as $\overline{RD}$ (CRRWR = 0), this pin provides an active<br>low $\overline{RD}$ strobe. When configured as E (CRRWR = 1), this pin<br>becomes an active high pulse, which, together with $R/\overline{W}$ defines the<br>cycle type. Then, if $R/W$ = 1 and E = 1, a read operation is executed.<br>If $R/\overline{W}$ = 0 and E = 1, a write operation is executed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

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

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

- 2. PSD302/312/303/313 only.
- 3. PSD301/311 only.

| Table 1.<br>PSD3XX Pin         | Name                                                 | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------------------------------|------------------------------------------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <i>Descriptions</i><br>(Cont.) | CSI/A19                                              | I    | This pin has two configurations. When it is $\overline{CSI}$ (CA19/ $\overline{CSI}$ = 0) and the pin is asserted high, the device is deselected and powered down. (See Tables 12 and 13 for the chip state during power-down mode.) If the pin is asserted low, the chip is in normal operational mode. When it is configured as A19, (CA19/ $\overline{CSI}$ = 1), this pin can be used as an additional input to the PAD. CADLOG3 = 1 defines the pin as an address; CADLOG3 = 0 defines it as a logic input. If it is an address, A19 can be latched with ALE (CADDHLT = 1) or be a transparent logic input (CADDHLT = 0). In this mode, there is no power-down capability.                                                                                                                                                                                                                 |
|                                | RESET                                                | 1    | The user-programmable pin can be configured to reset on high level (CRESET = 1) or on low level (CRESET = 0). It should remain active for at least 100 ns. See Tables 10a, 10b and 11 for the chip state after reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                | ALE<br>or<br>AS                                      | -    | In the multiplexed modes, the ALE pin functions as an Address<br>Latch Enable or as an Address strobe and can be configured as<br>an active high or active low signal. The ALE or AS trailing edge<br>latches lines AD15/A15–AD0/A0 and A16–A19 in 1 <u>6-bit</u> mode<br>(AD7/A7–AD0/A0 and A16–A19 in 8-bit mode) and BHE,<br>depending on the PSD3XX configuration. See Table 8. In the<br>non-multiplexed modes, it can be used as a general-purpose<br>logic input to the PAD.                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                | PA7<br>PA6<br>PA5<br>PA4<br>PA3<br>PA2<br>PA1<br>PA0 | I/O  | PA7–PA0 is an 8-bit port that can be configured to track<br>AD7/A7–AD0/A0 from the input (CPAF2 = 1). Otherwise<br>(CPAF2 = 0), each bit can be configured separately as an I/O or<br>lower-order latched address line. When configured as an I/O<br>(CPAF1 = 0), the direction of the pin is defined by its direction bit,<br>which resides in the direction register. If a pin is an I/O output, its<br>data bit (which resides in the data register) comes out. When it is<br>configured as a low-order address line (CPAF1 =1), A7–A0<br>can be made the corresponding output through this port (e.g., PA6<br>can be configured to be the A6 address line). Each port bit<br>can be a CMOS output (CPACOD = 0) or an open drain output<br>(CPACOD = 1). When the chip is in non-multiplexed mode<br>(CADDRAT = 0), the port becomes the data bus lines (D0–D7).<br>See Figure 4.            |
|                                | PB7<br>PB6<br>PB5<br>PB4<br>PB3<br>PB2<br>PB1<br>PB0 | I/O  | PB7–PB0 is an 8-bit port for which each bit can be configured as<br>an I/O (CPBF = 1) or chip-select output (CPBF = 0). Each port bit<br>can be a CMOS output (CPBCOD = 0) or an open drain output<br>(CPBCOD = 1). When configured as an I/O, the direction of the<br>pin is defined by its direction bit, which resides in the direction<br>register. If a pin is an I/O output, its data (which resides in the data<br>register) comes out. When configured as a chip-select output,<br>$\overline{CS0}$ – $\overline{CS3}$ are a function of up to four product terms of the inputs to<br>the PAD B; $\overline{CS4}$ ,– $\overline{CS7}$ then are each a function of up to two<br>product terms. On the PSD301L/302L/303L, when the chip is in<br>non-multiplexed mode (CADDRAT = 0) and the data bus width is<br>16 (CDATA = 1), the port becomes the data bus (D8–D15).<br>See Figure 6. |

| Table 1.<br>PSD3XX Pin                | Name                                                                                     | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------------------------------|------------------------------------------------------------------------------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PSDSXX FIN<br>Descriptions<br>(Cont.) | PC0<br>PC1<br>PC2                                                                        | 1/0  | This is a 3-bit port for which each bit is configurable as a PAD A<br>and B input or output. When configured as an input (CPCF = 0),<br>a bit individually becomes an address (CADLOG = 1) or a logic<br>input (CADLOG = 0). The addresses can be latched with ALE<br>(CADDHLT = 1) or be transparent inputs to the PADs<br>(CADDHLT = 0). When a pin is configured as an output (CPCF = 1),<br>it is a function of one product term of all PAD inputs.<br>See Figure 7. |
|                                       | AD0/A0<br>AD1/A1<br>AD2/A2<br>AD3/A3<br>AD4/A4<br>AD5/A5<br>AD6/A6<br>AD7/A7             | I/O  | In multiplexed mode, these pins are the multiplexed low-order<br>address/data byte. After ALE latches the addresses, these<br>pins input or output data, depending on the settings of the $\overline{RD}/E$<br>( $\overline{RD}/E/\overline{DS}$ on the PSD302/303), $\overline{WR}/V_{PP}$ or $R/\overline{W}$ , and $\overline{BHE}/\overline{PSEN}$<br>pins. In non-multiplexed mode, these pins are the low-order<br>address input.                                  |
|                                       | AD8/A8<br>AD9/A9<br>AD10/A10<br>AD11/A11<br>AD12/A12<br>AD13/A13<br>AD14/A14<br>AD15/A15 | I/O  | In 16-bit multiplexed mode, these pins are the multiplexed<br>high-order address/data byte. After ALE latches the addresses, these<br>pins input or output data, depending on the settings of the $\overline{RD}/E$ or<br>$\overline{RD}/E/DS$ , $\overline{WR}/V_{PP}$ or $R/W$ , and $\overline{BHE}/\overline{PSEN}$ pins. In all other modes,<br>these pins are the high-order address input.                                                                        |
|                                       | GND                                                                                      | Р    | V <sub>SS</sub> (ground) pin.                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                       | V <sub>cc</sub>                                                                          | Р    | Supply voltage input.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

#### Operating The PSD3XX's four operating modes enable it to interface directly to 8- and 16-bit microcontrollers with multiplexed and non-multiplexed address/data buses. These operating modes are: Multiplexed 8-bit address/data bus

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

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

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

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

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

#### Non-Multiplexed Address/Data. 8-bit Data Bus

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

#### Non-Multiplexed Address/Data, 16-bit Data Bus

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

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

# Modes

# **PSD3XX** Family



#### Figure 20. PSD3XX Port Configurations (x8 Only)



**Legend:** AD8-AD15 = Addresses A8-A15 multiplexed with data lines D8-D15. AD0-AD7 = Addresses A0-A7 multiplexed with data lines D0-D7.

**PSD3XX** Family

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

| Table 2a.                |                | Multiplexed Address/Data                                                        | Non-Multiplexed Address/Data           |
|--------------------------|----------------|---------------------------------------------------------------------------------|----------------------------------------|
| PSD31X Bus               | 8-bit Data Bus | • <u></u>                                                                       | •••••••••••••••••••••••••••••••••••••• |
| Configuration<br>Options | Port A         | I/O or low-order address<br>lines or Low-order multiplexed<br>address/data byte | D0–D7 data bus byte                    |
|                          | Port B         | I/O or CS0-CS7                                                                  | I/O and/or CS0–CS7                     |
|                          | AD0/A0-AD7/A7  | Low-order multiplexed address/data byte                                         | Low-order address bus byte             |
|                          | A8–A15         | High-order address bus byte                                                     | High-order address bus byte            |

#### *Programmable Address Decoder (PAD)*

The PSD3XX consists of two programmable arrays referred to as PAD A and PAD B (Figure 3). PAD A is used to generate chip select signals derived from the input address to the internal EPROM blocks, SRAM, I/O ports, and Track Mode signals. All its I/O functions are listed in Table 3 and shown in Figure 3. PAD B outputs to Ports B and C for off-chip usage.

PAD B can also be used to extend the decoding to select external devices or as a random logic replacement. The input bus to both PAD A and PAD B is the same.

Using MAPLE software, each programmable bit in the PAD's array can have one of three logic states of 0, 1, and don't care (X). In a user's logic design, both PADs can share the same inputs using the X for input signals that are not supposed to affect other functions. The PADs use reprogrammable CMOS EPROM technology and can be programmed and erased by the user.

# **PSD3XX** Family



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

- 5. RESET deselects all PAD output signals. See Tables 10 and 11.
- 6. A18, A17, and A16 are internally multiplexed with CS10, CS9, and CS8, respectively. Either A18 or CS10, A17 or CS9, and A16 or CS8 can be routed to the external pins of Port C. Port C can be configured as either input or output.
- 7. P<sub>0</sub>-P<sub>3</sub> are not included on PSD3X1 devices.

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

# Field-programmable microcontroller peripherals

# **PSD3XX** Family

| Configuration<br>Bits | The configuration bits shown in Table 4 are<br>non-volatile cells that let the user set the<br>device, I/O, and control functions to the<br>proper operational mode. Table 5 lists all<br>configuration bits. The configuration bits<br>are programmed and verified during the | programming phase. In operational mode,<br>they are not accessible. To simplify<br>implementing a specific mode, use the<br>PSD3XX MAPLE software to set the bits. |
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|

| Table 4.      |
|---------------|
| PSD3XX        |
| Non-Volatile  |
| Configuration |
| Bits          |
|               |

| Use This Bit       | То                                                                                                                                                                               |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CDATA              | Set the data bus width to 8 or 16 bits (PSD30X only).                                                                                                                            |
| CADDRDAT           | Set the address/data buses to multiplexed or non-multiplexed mode.                                                                                                               |
| CEDS               | Determine the polarity and functionality of read and write. (Note 9)                                                                                                             |
| CA19/CSI           | Set A19/CSI to CSI (power-down) or A19 input.                                                                                                                                    |
| CALE               | Set the ALE polarity.                                                                                                                                                            |
| CPAF2              | Set Port A either to track the low-order byte of the address/data multiplexed bus or to select the I/O or address option.                                                        |
| CSECURITY          | Set the security on or off (a secured part can not be duplicated).                                                                                                               |
| CRESET             | Set the RESET polarity.                                                                                                                                                          |
| COMB/SEP           | Set PSEN and RD for combined or separate address spaces (see Figures 9 and 10).                                                                                                  |
| CPAF1<br>(8 Bits)  | Configure each pin of Port A in multiplexed mode to be an I/O or address out.                                                                                                    |
| CPACOD<br>(8 Bits) | Configure each pin of Port A as an open drain or active CMOS pull-up output.                                                                                                     |
| CPBF<br>(8 Bits)   | Configure each pin of Port B as an I/O or a chip-select output.                                                                                                                  |
| CPBCOD<br>(8 Bits) | Configure each pin of Port B as an open drain or active CMOS pull-up output.                                                                                                     |
| CPCF<br>(3 Bits)   | Configure each pin of Port C as an address input or a chip-select output.                                                                                                        |
| CADDHLT            | Configure pins A16 – A19 to go through a latch or to have their latch transparent.                                                                                               |
| CADLOG<br>(4 Bits) | Configure A16 – A19 individually as logic or address inputs. (Note 9)                                                                                                            |
| CATD               | Configure pins A16–A19 as PAD logic inputs or high-order address inputs (Note 8).                                                                                                |
| CLOT               | Determine in non-multiplexed mode if address inputs are transparent or latched (Note 9).                                                                                         |
| CRRWR              | Set the $\overline{RD}/E$ and $\overline{WR}/V_{PP}$ or $\overline{R/W}$ pins to $\overline{RD}$ and $\overline{WR}$ pulse, or to E strobe and $\overline{R/W}$ status (Note 8). |
| CRRWR              | Configure the polarity and control methods of read and write cycles. (Note 9)                                                                                                    |
|                    |                                                                                                                                                                                  |

**Port Functions** 

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

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



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





| Table 5.<br>PSD3XX                     | Configuration<br>Bits      | No.<br>of Bits | Function                                                                                                                                                                                                                                                  |
|----------------------------------------|----------------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Configuration<br>Bits <sup>12,13</sup> | CDATA<br>(Note 14)         | 1              | 8-bit or 16-bit Data Bus Width<br>CDATA = 0 eight bits<br>CDATA = 1 sixteen bits                                                                                                                                                                          |
|                                        | CADDRDAT                   | 1              | ADDRESS/DATA Multiplexed (separate buses)<br>CADDRDAT = 0, non-multiplexed<br>CADDRDAT = 1, multiplexed                                                                                                                                                   |
|                                        | CA19/CSI                   | 1              | A19 or $\overline{CSI}$<br>CA19/ $\overline{CSI}$ = 0, enable power-down<br>CA19/ $\overline{CSI}$ = 1, enable A19 input to PAD                                                                                                                           |
|                                        | CALE                       | 1              | Active HIGH or Active LOW<br>CALE = 0, Active high<br>CALE = 1, Active low                                                                                                                                                                                |
|                                        | CRESET                     | 1              | Active high or active low<br>CRESET = 0, active low reset signal<br>CRESET = 1, active high reset signal                                                                                                                                                  |
|                                        | COMB/SEP                   | 1              | Combined or Separate Address Space<br>for SRAM and EPROM<br>0 = Combined, 1 = Separate                                                                                                                                                                    |
|                                        | CPAF1                      | 8              | Port A I/Os or A0–A7<br>CPAF1 = 0, Port A pin = I/O<br>CPAF1 = 1, Port A pin = A0 – A7                                                                                                                                                                    |
|                                        | CPAF2                      | 1              | Port A AD0–AD7 (address/data multiplexed bus)<br>CPAF2 = 0, address or I/O on Port A (according to CPAF1)<br>CPAF2 = 1, address/data multiplexed on Port A (track mode)                                                                                   |
|                                        | CATD<br>(Note 16)          | 1              | A16–A19 address or logic inputs<br>CATD = 0, logic inputs<br>CATD = 1, address inputs                                                                                                                                                                     |
|                                        | CADDHLT                    | 1              | A16–A19 Transparent or Latched<br>CADDHLT = 0, Address latch transparent<br>CADDHLT = 1, Address latched (ALE dependent)                                                                                                                                  |
|                                        | CSECURITY                  | 1              | SECURITY On/Off<br>CSECURITY = 0, off<br>CSECURITY = 1, on                                                                                                                                                                                                |
|                                        | CLOT<br>(Note 15)          | 1              | A0–A15 Address Inputs are transparent or<br>ALE-dependent in non-multiplexed modes<br>CLOT = 0, transparent<br>CLOT = 1, ALE-dependent                                                                                                                    |
|                                        | CRRWR<br>CEDS<br>(Note 15) | 2              | Determine the polarity and control methods of read and write cycles.         CEDS       CRRWR         0       0       RD and WR active low pulses         0       1       R/W status and high E pulse         1       1       R/W status and low DS pulse |
|                                        | CRRWR<br>(Note 16)         | 1              | CRRWR = 0, $\overline{RD}$ and $\overline{WR}$ active low strobes<br>CRRWR = 1, R/W status and E active high pulse                                                                                                                                        |
|                                        | CPACOD                     | 8              | Port A CMOS or Open Drain Output<br>CPACOD = 0, CMOS output<br>CPACOD = 1, open-drain output                                                                                                                                                              |

# **PSD3XX** Family

| Configuration<br>Bits | No.<br>of Bits | Function                                                                                                                                                         |
|-----------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CPBF                  | 8              | Port B is I/O or $\overline{CS0}$ – $\overline{CS7}$<br>CPBF = 0, Port B pin is CS0 – $\overline{CS7}$<br>CPBF = 1, Port B pin is I/O                            |
| CPBCOD                | 8              | Port B CMOS or Open Drain<br>CPBCOD = 0, CMOS output<br>CPBCOD = 1, open-drain output                                                                            |
| CPCF                  | 3              | Port C A16-A18 or $\overline{CS8}$ - $\overline{CS10}$<br>CPCF = 0, Port C pin is <u>A16-A18</u><br>CPCF = 1, Port C pin is $\overline{CS8}$ - $\overline{CS10}$ |
| CADLOG<br>(Note 15)   | 4              | Port C: A16–A19 Address or Logic Input<br>CADLOG = 0, Port C pin or A19/CSI is logic input<br>CADLOG = 1, Port C pin or A19/CSI is address input                 |
| CMISER                | 1              | Default: CMISER = 0<br>CMISER = 1, lower-power mode                                                                                                              |

NOTES: 12. The Maple software will guide the user to the proper configuration choice.

13. In an unprogrammed or erased part, all configuration bits are 0.

14. PSD30X only.

15. PSD3X2/3X3 only.

16. PSD3X1 only.

#### Port Functions (Cont.)

Table 5. PSD3XX Configuration Bits (Cont.)

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

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

Alternatively, each bit of Port A can be configured as a low-order latched address bus bit. The address is provided by the port address latch, which latches the address on the trailing edge of ALE. PA0–PA7 can become A0–A7, respectively. This feature enables the user generate low-order address bits to access external peripherals or memory that require several low-order address lines. Another mode of Port A (CPAF2 = 1) sets the entire port to track the inputs AD0/A0-AD7/A7, depending on specific address ranges defined by the PAD's CSADIN, CSADOUT1, and CSADOUT2 signals. This feature lets the user interface the microcontroller to shared external resources without requiring external buffers and decoders. In this mode, the port is effectively a bi-directional buffer. The direction is controlled by using the input signals ALE, RD/E or RD/E/DS, WR/VPP or R/W, and the internal PAD outputs CSADOUT1, CSADOUT2 and CSADIN (see Figure 5). When CSADOUT1 and ALE are true, the address on the input AD0/A0–AD7/A7 pins is output through Port A. (Carefully check the generation of CSADOUT1, and ensure that it is stable during the ALE pulse. When CSADOUT2 is active, a write operation is performed (see note to Figure 5). The data on the input AD0/A0-AD7/A7 pins flows out through Port A. When CSADIN and a read operation is performed (depending on the mode of the RD/E or RD/E/DS, and WR/VPP or R/W pins), the data on Port A flows out through the AD0/A0-AD7/A7 pins. In this operational mode, Port A is tri-stated when none of the above-mentioned three conditions exist.

#### Port Functions (Cont.)

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

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

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

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

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

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

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

#### Accessing the I/O Port Registers

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

#### Port C in All Modes

Each pin of Port C (shown in Figure 7) can be configured as an input to PAD A and PAD B or output from PAD B. As inputs, the pins are named A16-A18. Although the pins are given names of the high-order address bus, they can be used for any other address lines or logic inputs to PAD A and PAD B. For example, A8-A10 can also be connected to those pins, improving the boundaries of CS0-CS7 resolution to 256 bytes. As inputs, they can be individually configured to be logic or address inputs. A logic input uses the PAD only for Boolean equations that are implemented in any or all of the CS0–CS10 PAD B outputs. Port C addresses can be programmed to latch the inputs by the trailing edge ALE or to be transparent.

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

#### ALE/AS and ADO/AO–AD15/A15 in Non-Multiplexed Modes

In non-multiplexed modes. AD0/A0-AD15/A15 are address inputs only and can become transparent (CLOT = 0) or ALE dependent (CLOT = 1). In transparent mode, the ALE/AS pin can be used as an additional logic input to the PADs. The nonmultiplexed ALE dependent mode is useful in applications for which the host processor has a multiplex address/data bus and AD0/A0-AD7/A7 are not multiplexed with A0-A7 but rather are multiplexed with other address lines. In these applications, Port A serves as a data bus and each of its pins can be directly connected to the corresponding host's multiplexed pin, where that data bit is expected. (See Table 8.)

# **PSD3XX** Family

#### Figure 6. Port B Pin Structure



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

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

| Table 7.<br>I/O Port                      | Register Name                       | Word Size Access of the I/O Port Registers<br>Offset from the CSIOPORT |
|-------------------------------------------|-------------------------------------|------------------------------------------------------------------------|
| <i>Addresses in a<br/>16-bit Data Bus</i> | Pin Register of Ports B and A       | + 2 (accessible during read operation only)                            |
| Mode <sup>18,19</sup>                     | Direction Register of Ports B and A | + 4                                                                    |
| (PSD30X)                                  | Data Register of Ports B and A      | + 6                                                                    |

NOTES: 18. When the data bus width is 16, Port B registers can only be accessed if the BHE signal is low.

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

# **PSD3XX** Family



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

 PSD3X2/3X3: Individual pins can be configured independently as address or logic inputs (CADLOG, bits 0–2).

PSD3X1: All Port C pins are either address or logic inputs (CATD).

#### Port Functions (Cont.)

#### ALE/AS and ADO/AO–AD15/A15 in Non-Multiplexed Modes (PSD3X2/3X3)

In non-multiplexed modes,

AD0/A0–AD15/A15 are address inputs only and can become transparent (CLOT = 0) or ALE dependent (CLOT = 1). In transparent mode, the ALE/AS pin can be used as an additional logic input to the PADs. The nonmultiplexed ALE dependent mode is useful in applications for which the host processor has a multiplex address/data bus and AD0/A0–AD7/A7 are not multiplexed with A0–A7 but rather are multiplexed with other address lines. In these applications, Port A serves as a data bus and each of its pins can be directly connected to the corresponding host's multiplexed pin, where that data bit is expected. (See Table 8.)

#### ALE/AS and ADO/AO–AD7/A7 in Non-Multiplexed Modes (PSD31X)

In non-multiplexed modes, A0-A15 are address inputs only and can become transparent (CLOT = 0) or ALE dependent (CLOT = 1). In transparent mode, the ALE/AS pin can be used as an additional logic input to the PADs. The non-multiplexed ALE dependent mode is useful in applications for which the host processor has a multiplex address/data bus and AD0/A0-AD7/A7 are not multiplexed with A0-A7 but rather are multiplexed with other address lines. In these applications, Port A serves as a data bus and each of its pins can be directly connected to the corresponding host's multiplexed pin, where that data bit is expected. (See Table 8.)

A16-A19If one or more of the pins PC0, PC1 PC2<br/>and CSI/A19 are configured as inputs, the<br/>configuration bits CADDHLT and CATD<br/>define their functionality inside the part.<br/>CADDHLT determines if these inputs are to<br/>be latched by the trailing edge of the<br/>ALE or AS signal (CADDHLT = 1), or<br/>enabled into the PSD3XX at all times<br/>(CADDHLT = 0, transparent mode). CATD

determines whether these lines are highorder address lines, that take part in the derivation of memory and I/O select signals inside the chip (CATD = 1), or logic input lines that have no impact on memory or I/O selections (CATD = 0). Logic input lines typically participate in the Boolean expressions implemented in the PAD.

#### **EPROM**

The EPROM has 8 banks of memory. Each bank can be placed in any address location by programming the PAD. Bank0–Bank7 is selected by PAD outputs ES0-ES7, respectively.

| Device | EPROM<br>Size | EPROM<br>Architecture |          | Archit  | A Bank<br>ecture<br>ea) |
|--------|---------------|-----------------------|----------|---------|-------------------------|
|        |               | x8                    | x16      | x8      | x16                     |
| PSD301 | 256Kb         | 32K x 8               | 16K x 16 | 4K x 8  | 2K x 16                 |
| PSD311 | 256Kb         | 32K x 8               | -        | 4K x 8  | -                       |
| PSD302 | 512Kb         | 64K x 8               | 32K x 16 | 8K x 8  | 4K x 16                 |
| PSD312 | 512Kb         | 64K x 8               | -        | 8K x 8  | -                       |
| PSD303 | 1Mb           | 128K x 8              | 64K x 16 | 16K x 8 | 8K x 16                 |
| PSD313 | 1Mb           | 128K x 8              | -        | 16K x 8 | -                       |

#### SRAM

Each PSD3XX device has 16K bits of SRAM. Depending on the configuration of the data bus, the SRAM organization can be 2K x 8 (8-bit data bus) or 1K x 16 (16-bit data bus). The SRAM is selected by the RS0 output of the PAD.

# Memory Paging<br/>(PSD3X2/3X3)The page register consists of four<br/>flip-flops, which can be read from, or<br/>written to, through the I/O address space<br/>(CSIOPORT). The page register is<br/>connected to the D3–D0 lines. The Page<br/>Register address is CSIOPORT + 18H. Thepage register outputs are P3–P0, which are<br/>fed into the PAD. This enables the host<br/>microcontroller to enlarge its address<br/>space by a factor of 16 (there can be a<br/>maximum of 16 pages). See Figure 8.

May, 1993

# **PSD3XX** Family



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

#### **Control Signals**

The PSD3XX control signals are  $\overline{WR}/V_{PP}$ or  $\overline{R}/\overline{W}$ ,  $\overline{RD}/E$  or  $\overline{RD}/E/\overline{DS}$ , ALE, BHE/PSEN or PSEN, RESET, and A19/CSI. Each of these signals can be configured to meet the output control signal requirements of various microcontrollers.

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

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

#### RD/E/DS (or RD/E on PSD3X1)

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

As  $\overline{\text{DS}}$ , the pin functions with the R/ $\overline{\text{W}}$  signal as an active low data strobe signal. As  $\overline{\text{DS}}$ , the R/ $\overline{\text{W}}$  defines the mode of operation (Read or Write).

#### ALE or AS

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

#### BHE/PSEN

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

Whenever a member of the 8031 family (or any other similar microcontroller) is used, the PSEN pin must be connected to the PSEN pin of the microcontroller.

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

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

#### RESET

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

# **PSD3XX** Family

#### Control Signals (Cont.)

#### A19/CSI

When configured as  $\overline{\text{CSI}}$ , a high on this pin deselects, and powers down, the chip. A low on this pin puts the chip in normal operational mode. For PSD3XX states during the power-down mode, see Tables 12 and 13, and Figure 11. In A19 mode, the pin is an additional input to the PAD. It can be used as an address line (CADLOG3 = 1) or as a generalpurpose logic input (CADLOG3 = 0). A19 can be configured as ALE dependent or as transparent input (see Table 8). In this mode, the chip is always enabled.



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



| Table 10a.<br>Signal States | Signal           | Condition |  |
|-----------------------------|------------------|-----------|--|
| During Reset                | AD0/A0-AD15/A15  | Input     |  |
| Cycle (RESET)               | PA0-PA7 (Port A) | Input     |  |
|                             | PB0–PB7 (Port B) | Input     |  |
|                             | PC0-PC2 (Port C) | Input     |  |

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

#### Field-programmable microcontroller peripherals

# **PSD3XX** Family

| Table 11.                               | Component            | Signals                                                    | Contents          |
|-----------------------------------------|----------------------|------------------------------------------------------------|-------------------|
| Internal States                         |                      | CS0-CS10                                                   | All = 1 (Note 22) |
| <i>During and After<br/>Reset Cycle</i> | PAD                  | CSADIN, CSADOUT1,<br>CSADOUT2, CSIOPORT,<br>RS0, ES0 – ES7 | All = 0 (Note 22) |
|                                         | Data register A      | n/a                                                        | 0                 |
|                                         | Direction register A | n/a                                                        | 0                 |
|                                         | Data register B      | n/a                                                        | 0                 |
|                                         | Direction register B | n/a                                                        | 0                 |

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



NOTES: 23. The CADDHLT configuration bit determines if A19-A16 are transparent via the latch, or if they must be latched by the trailing edge of the ALE strobe.

# **PSD3XX** Family

| able 12a. Signal             | Signal          | Configuration Mode                                                        | Condition                          |
|------------------------------|-----------------|---------------------------------------------------------------------------|------------------------------------|
| tates During                 | AD0/A0-AD15/A15 | All                                                                       | Input                              |
| ower-Down<br>Iode<br>ISD30X) | PA0-PA7         | I/O<br>Tracking AD0/A0–AD7/A7<br>Address outputs A0–A7                    | Unchanged<br>Input<br>All 1's      |
|                              | PB0PB7          | I/O<br><u>CS0</u> – <u>CS7</u> CMOS outputs<br>CS0–CS7 open drain outputs | Unchanged<br>All 1's<br>Tri-stated |
|                              | PC0-PC2         | Address inputs A18–A16<br>CS8–CS10 CMOS outputs                           | Input<br>All 1's                   |

| Table 12b.<br>Sizzal States    | Signal        | Configuration Mode                                        | Condition                          |
|--------------------------------|---------------|-----------------------------------------------------------|------------------------------------|
| Signal States<br>Suring Power- | AD0/A0-AD7/A7 | All                                                       | Input                              |
| own Mode                       | A8-A15        | All                                                       | Input                              |
| PSD31X)                        | PA0-PA7       | I/O<br>Tracking AD0/A0–AD7/A7<br>Address outputs A0–A7    | Unchanged<br>Input<br>All 1's      |
|                                | PB0-PB7       | I/O<br>CS0–CS7 CMOS outputs<br>CS0–CS7 open drain outputs | Unchanged<br>All 1's<br>Tri-stated |
|                                | PC0-PC2       | Address inputs A18–A16<br>CS8–CS10 CMOS outputs           | Input<br>All 1's                   |

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

# **PSD3XX** Family



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

System In Figure 12, the PSD3XX is configured to In Figure 13, the PSD3XX is configured to interface with Motorola's 68HC11, which interface with Intel's 80C31, which is a 16-**Applications** bit address/8-bit data bus microcontroller. is a 16-bit address/8-bit data bus Its data bus is multiplexed with the lowmicrocontroller. Its data bus is multiplexed order address byte. The 80C31 uses with the low-order address byte. The signals RD to read from data memory and 68HC11 uses E and R/W signals to derive PSEN to read from code memory. It uses the read and write strobes. It uses the term WR to write into the data memory. It also AS (address strobe) for the address latch uses active high reset and ALE signals. pulse. RESET is an active low signal. The The rest of the configuration bits as well as rest of the configuration bits as well as the the unconnected signals (not shown) are unconnected signals (not shown) are application specific and, thus, user specific and, thus, user dependent. dependent.

# **PSD3XX** Family



inputs, respectively. These signals are independent of the ALE pulse (latchtransparent). They are used as four general-purpose logic inputs that take part in the PAD equations implementation.

CSI/A19 as A16, A17, A18, and A19

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

# **PSD3XX** Family

#### *Figure 14. PSD3XX Interface With Intel's 80C196KB.*



The configuration bits for Figure 14 are:

| CALE     | 0          | CSECURITY           | Don't care |
|----------|------------|---------------------|------------|
| CDATA    | 1          | CPCF2, CPCF1, CPCF0 | 0, 0, 0    |
| CADDRDAT | 1          | CPACOD7-CPACOD0     | 00H        |
| CPAF1    | Don't care | CPBF7–CPBF0         | 00H        |
| CPAF2    | 1          | CPBCOD7-CPBCOD0     | 18H        |
| CA19/CSI | 1          | CEDS                | 0          |
| CRRWR    | 0          | CADLOG3—CADLOG0     | 0H         |
| COMB/SEP | 0          |                     |            |
| CADDHLT  | 0          |                     |            |
| CRESET   | 0          |                     |            |

May, 1993

# **PSD3XX Family**

May, 1993

# Field-programmable microcontroller peripheral

#### Key Features

- Single Chip Programmable Peripheral for Microcontroller-based Applications
- 19 Individually Configurable I/O pins that can be used as:
- Microcontroller I/O port expansion
- Programmable Address Decoder (PAD) I/O
- Latched address output
- Open drain or CMOS
- Two Programmable Arrays (PAD A and PAD B)
- --- Total of 40 Product Terms and up to 16 Inputs and 24 Outputs
- Address Decoding up to 1 MB
- Logic replacement
- "No Glue" Microcontroller Chip-Set
- Built-in address latches for multiplexed address/data bus
- Non-multiplexed address/data bus mode
- Selectable 8 or 16 bit data bus width
- ALE and Reset polarity programmable
- --- Selectable modes for read and write control bus as RD/WR or R/W/E
- BHE pin for byte select in 16-bit mode
- PSEN pin for 8051 users
- 256 Kbits of UV EPROM
- Configurable as 32K x 8 or as 16K x 16
- Divides into 8 equal mappable blocks for optimized mapping
- Block resolution is 4K x 8 or 2K x 16
- 120 ns EPROM access time, including input latches and PAD address decoding.

- 16 Kbit Static RAM
- Configurable as 2K x 8 or as 1K x 16
- 120 ns SRAM access time, including input latches and PAD address decoding
- Address/Data Track Mode
- Enables easy Interface to Shared Resources (e.g., Mail Box SRAM) with other Microcontrollers or a Host Processor
- Built-In Security
- Locks the PSD301 and PAD Decoding Configuration
- Available in a Choice of Packages
- 44 Pin PLCC and CLCC
- 52 Pin PQFP
- Simple Menu-Driven Software: Configure the PSD301 on an IBM PC
- Pin Compatible with the PSD3XX and PSD3XXL Family

#### **PSD301**

| Security<br>Mode | Security Mode in the PSD3XX locks the contents of the PAD A, PAD B and all the configuration bits. The EPROM, SRAM, and I/O contents can be accessed only through the PAD. The Security Mode can                                                            | software. In window packages, the mode is<br>erasable through UV full part erasure. In<br>the security mode, the PSD3XX contents<br>cannot be copied on a programmer.                                                                                                                                                                           |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | be set by the MAPLE or Programming                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                 |
| CMiser-Bit       | The CMiser-Bit provides a programmable<br>option for power-sensitive applications that<br>require further reduction in power<br>consumption. The CMiser-Bit (CMiser = 1)<br>in the Maple portion of the PSD3XX sytem<br>development software can be used to | In the default mode, or if the PSD3XX is<br>configured without programming the<br>CMiser-Bit (CMiser = 0), the device<br>operates at specified speed and power<br>rating as specified in the A.C. and D.C.<br>Characteristics.                                                                                                                  |
|                  | reduce power consumption. The CMiser-Bit<br>turns off the EPROM blocks in the PSD3XX<br>whenever the EPROM is not accessed,<br>thereby reducing the active current<br>consumed by the PSD3XX.                                                               | However, if the CMiser-Bit is programmed<br>(CMiser = 1), the device consumes even<br>lower current, and is reflected in the data<br>sheet. This mode has an adder in<br>propagation delay in T5, T6, and T7<br>parameters in the A.C. Characteristics, and<br>should be added to compute worst-case<br>timing requirements in the application. |

#### Absolute Maximum Ratings<sup>1</sup>

| Symbol           | Parameter                     | Condition           | Min   | Max   | Unit |  |
|------------------|-------------------------------|---------------------|-------|-------|------|--|
| T                | Storage Temperature -         | CERDIP              | - 65  | + 150 | °C   |  |
| T <sub>STG</sub> |                               | PLASTIC             | - 65  | + 125 | °C   |  |
|                  | Voltage on any Pin            | With Respect to GND | - 0.6 | +7    | V    |  |
| V <sub>PP</sub>  | Programming<br>Supply Voltage | With Respect to GND | - 0.6 | + 14  | v    |  |
| V <sub>cc</sub>  | Supply Voltage                | With Respect to GND | - 0.6 | +7    | v    |  |
|                  | ESD Protection                |                     |       | >2000 | V    |  |

NOTE: 1. 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 theses or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to Absolute Maximum Rating conditions for extended periods of time may affect device reliability.

| Operating<br>Range | Range      | Temperature      | V <sub>CC</sub> | V <sub>CC</sub> Tolerance |       |       |  |  |
|--------------------|------------|------------------|-----------------|---------------------------|-------|-------|--|--|
|                    | Jungo      | iemperature      | - 00            | -12                       | -15   | -20   |  |  |
|                    | Commercial | 0° C to +70°C    | + 5 V           | ± 10%                     | ± 10% | ± 10% |  |  |
|                    | Industrial | -40° C to +80°C  | + 5 V           |                           | ± 10% | ± 10% |  |  |
|                    | Military   | -55° C to +125°C | + 5 V           |                           |       | ± 10% |  |  |

| Recommended<br>Operating | y V <sub>cc</sub> Supply | Parameter                | Conditions                                 | Min | Тур | Max | Unit |
|--------------------------|--------------------------|--------------------------|--------------------------------------------|-----|-----|-----|------|
| Conditions               | V <sub>cc</sub>          | Supply Voltage           | All Speeds                                 | 4.5 | 5   | 5.5 | V    |
| vonunnono                | VIH                      | High-level Input Voltage | V <sub>CC</sub> = 4.5 V to 5.5 V           | 2   |     |     | V    |
|                          | VIL                      | Low-level Input Voltage  | $V_{CC} = 4.5 \text{ V to } 5.5 \text{ V}$ | 0   |     | 0.8 | V    |

DC

**Characteristics** 

# Field-programmable microcontroller peripheral

**PSD301** 

| Symbol           | Parameter                                                                             | Conditions                                                   |     |      |      |     | Miser<br>Ibtrac |     |     |
|------------------|---------------------------------------------------------------------------------------|--------------------------------------------------------------|-----|------|------|-----|-----------------|-----|-----|
| -                |                                                                                       |                                                              | Min | Тур  | Max  | Min | Тур             | Max | Uni |
| V <sub>OL</sub>  | Output Low                                                                            | I <sub>OL</sub> = 20 μA<br>V <sub>CC</sub> = 4.5 V           |     | 0.01 | 0.1  |     |                 |     | v   |
| , OL             | Voltage                                                                               | l <sub>OL</sub> = 8 mA<br>V <sub>CC</sub> = 4.5 V            |     | 0.15 | 0.45 |     |                 |     | v   |
| V <sub>OH</sub>  | Output High                                                                           | l <sub>OH</sub> =20 μA<br>V <sub>CC</sub> = 4.5 V            | 4.4 | 4.49 |      |     |                 |     | v   |
| чон              | Voltage                                                                               | Voltage $I_{OH} = -2 \text{ mA}$<br>$V_{CC} = 4.5 \text{ V}$ |     | 3.9  |      |     |                 |     | v   |
| lan i            | V <sub>CC</sub> Standby<br>Current (CMOS)                                             | Comm'l                                                       |     | 50   | 100  |     |                 |     | μA  |
| SB1              | (Notes 2 and 4)                                                                       | Ind/Mil                                                      |     | 75   | 150  |     |                 |     | μA  |
|                  |                                                                                       | Comm'l<br>(Note 6)                                           |     | 16   | 35   |     | 7               | 10  | mA  |
|                  | Active Current<br>(CMOS) (No<br>Internal Memory<br>Block Selected)<br>(Notes 2 and 5) | Comm'l<br>(Note 7)                                           |     | 28   | 50   |     | 7               | 10  | mA  |
|                  |                                                                                       | Ind/Mil<br>(Note 6)                                          | -   | 16   | 45   |     | 7               | 10  | mA  |
|                  | (                                                                                     | Ind/Mil<br>(Note 7)                                          |     | 28   | 60   |     | 7               | 10  | mA  |
| -                |                                                                                       | Comm'l<br>(Note 6)                                           |     | 16   | 35   |     | 0               | 0   | mA  |
| I <sub>CC2</sub> | Active Current<br>(CMOS) (EPROM                                                       | Comm'l<br>(Note 7)                                           |     | 28   | 50   |     | 0               | 0   | mA  |
|                  | Block Selected)<br>(Notes 2 and 5)                                                    | Ind/Mil<br>(Note 6)                                          |     | 16   | 45   |     | 0               | 0   | mA  |
|                  |                                                                                       | Ind/Mil<br>(Note 7)                                          |     | 28   | 60   |     | 0               | 0   | mA  |
|                  |                                                                                       | Comm'l<br>(Note 6)                                           |     | 47   | 80   |     | 7               | 10  | m/  |
| loon             | Active Current<br>(CMOS) (SRAM                                                        | Comm'l<br>(Note 7)                                           |     | 59   | 95   |     | 7               | 10  | m/  |
| I <sub>CC3</sub> | Block Selected<br>(Notes 2 and 5)                                                     | Ind/Mil<br>(Note 6)                                          |     | 47   | 100  |     | 7               | 10  | m/  |
|                  |                                                                                       | Ind/Mil<br>(Note 7)                                          |     | 59   | 115  |     | 7               | 10  | m/  |
| ILI              | Input Leakage<br>Current                                                              | V <sub>IN</sub> = 5.5 V<br>or GND                            | -1  | ±0.1 | 1    |     |                 |     | μA  |
| I <sub>LO</sub>  | Output Leakage<br>Current                                                             | V <sub>OUT</sub> = 5.5 V<br>or GND                           | -10 | ±5   | 10   |     |                 |     | μA  |

**NOTES:** 2. CMOS inputs: GND  $\pm$  0.3 V or V<sub>CC</sub>  $\pm$  0.3V. 3. TTL inputs: V<sub>IL</sub>  $\leq$  0.8 V, V<sub>IH</sub>  $\geq$  2.0 V. 4. CSI/A19 is high and the part is in a power-down configuration mode. 5. Add 3.0 mA/MHz for AC power component (power = AC + DC). 6. Ten (10) PAD product terms active. (Add 380 µA per product term, typical, or 480 µA per product term maximum

7. Forty-one (41) PAD product terms active.

### **PSD301**

### AC Characteristics

|        |                                                                   | -9  | 00  | -1  | 2   | -1  | 5   | -2  | 20  | CMiser = 1 |      |
|--------|-------------------------------------------------------------------|-----|-----|-----|-----|-----|-----|-----|-----|------------|------|
| Symbol | Parameter                                                         | Min | Max | Min | Max | Min | Max | Min | Max | Add:       | Unit |
| T1     | ALE or AS Pulse Width                                             | 20  |     | 30  |     | 40  |     | 50  |     | 0          | ns   |
| T2     | Address Set-up Time                                               | 5   |     | 9   |     | 12  |     | 15  |     | 0          | ns   |
| Т3     | Address Hold Time                                                 | 8   |     | 13  |     | 15  |     | 25  |     | 0          | ns   |
| T4     | Leading Edge of Read to Data Active                               | 0   |     | 0   |     | 0   |     | 0   |     | 0          | ns   |
| T5     | ALE Valid to Data Valid                                           |     | 100 |     | 140 |     | 170 |     | 200 | 10         | ns   |
| T6     | Address Valid to Data Valid                                       |     | 90  |     | 120 |     | 150 |     | 200 | 10         | ns   |
| T7     | CSI Active to Data Valid                                          |     | 100 |     | 150 |     | 160 |     | 200 | 15         | ns   |
| Т8     | Leading Edge of Read to Data Valid                                |     | 32  |     | 38  |     | 55  |     | 60  | 0          | ns   |
| Т9     | Read Data Hold Time                                               | 0   |     | 0   |     | 0   |     | 0   |     | 0          | ns   |
| T10    | Trailing Edge of Read to<br>Data High-Z                           |     | 35  |     | 35  |     | 40  |     | 45  | 0          | ns   |
| T11    | Trailing Edge of ALE or AS to Leading Edge of Write               | 0   |     | 0   |     | 0   |     | 0   |     | 0          | ns   |
| T12    | RD, E, PSEN, or DS<br>Pulse Width                                 | 40  |     | 45  |     | 60  |     | 75  |     | 0          | ns   |
| T12A   | WR Pulse Width                                                    | 20  |     | 25  |     | 35  |     | 45  |     | 0          | ns   |
| T13    | Trailing Edge of Write or<br>Read to Leading Edge<br>of ALE or AS | 0   |     | 0   |     | 0   |     | 0   |     | 0          | ns   |
| T14    | Address Valid to Trailing<br>Edge of Write                        | 90  |     | 120 |     | 150 |     | 200 |     | 0          | ns   |
| T15    | CSI Active to Trailing Edge<br>of Write                           | 100 |     | 130 |     | 160 |     | 200 |     | 0          | ns   |
| T16    | Write Data Set-up Time                                            | 20  |     | 25  |     | 30  |     | 40  |     | 0          | ns   |
| T17    | Write Data Hold Time                                              | 5   |     | 5   |     | 10  |     | 15  |     | 0          | ns   |
| T18    | Port to Data Out Valid<br>Propagation Delay                       |     | 30  |     | 30  |     | 35  |     | 45  | 0          | ns   |
| T19    | Port Input Hold Time                                              | 0   |     | 0   |     | 0   |     | 0   |     | 0          | ns   |
| T20    | Trailing Edge of Write to Port Output Valid                       | 40  |     | 40  |     | 50  |     | 60  |     | 0          | ns   |
| T21    | ADi or Control to CSOi<br>Valid                                   | 6   | 25  | 6   | 30  | 6   | 35  | 5   | 45  | 0          | ns   |
| T22    | ADi or Control to CSOi<br>Invalid                                 | 5   | 25  | 5   | 30  | 4   | 35  | 4   | 45  | 0          | ns   |

#### **PSD301**

#### AC Characteristics (Cont.)

|        | _                                                                                     | -9  | 00  | -1  | 2   | -1  | 5   | -2  | 20  | CMiser = 1 |      |
|--------|---------------------------------------------------------------------------------------|-----|-----|-----|-----|-----|-----|-----|-----|------------|------|
| Symbol | Parameter                                                                             | Min | Max | Min | Max | Min | Max | Min | Max | Add:       | Unit |
| T23    | Track Mode Address<br>Propagation Delay:<br>CSADOUT1 Already True                     |     | 22  |     | 22  |     | 22  |     | 28  | 0          | ns   |
| T23A   | Track Mode Address<br>Propagation Delay:<br>CSADOUT1 Becomes<br>True During ALE or AS |     | 33  |     | 33  |     | 40  |     | 50  | 0          | ns   |
| T24    | Track Mode Trailing Edge<br>of ALE or AS to Address<br>High-Z                         |     | 32  |     | 32  |     | 35  |     | 40  | 0          | ns   |
| T25    | Track Mode Read<br>Propagation Delay                                                  |     | 29  |     | 29  |     | 29  |     | 35  | 0          | ns   |
| T26    | Track Mode Read<br>Hold Time                                                          | 11  | 29  | 11  | 29  | 10  | 29  | 10  | 35  | 0          | ns   |
| T27    | Track Mode Write Cycle,<br>Data Propagation Delay                                     |     | 20  |     | 20  |     | 20  |     | 30  | 0          | ns   |
| T28    | Track Mode Write<br>Cycle, Write to Data<br>Propagation Delay                         | 8   | 30  | 8   | 30  | 7   | 40  | 7   | 55  | 0          | ns   |
| T29    | Hold Time of Port A<br><u>Valid</u> During Write<br>CSOi Trailing Edge                | 2   |     | 2   |     | 2   |     | 2   |     | 0          | ns   |
| T30    | CSI Active to CSOi Active                                                             | 9   | 40  | 9   | 45  | 9   | 45  | 8   | 60  | 0          | ns   |
| T31    | CSI Inactive to CSOi<br>Inactive                                                      | 9   | 40  | 9   | 45  | 9   | 45  | 8   | 60  | 0          | ns   |
| T32    | Direct PAD Input as<br>Hold Time                                                      | 10  |     | 10  |     | 12  |     | 15  |     | 0          | ns   |
| T33    | R/W Active to E High                                                                  | 20  |     | 20  |     | 30  |     | 40  |     | 0          | ns   |
| T34    | E End to R/W                                                                          | 20  |     | 20  |     | 30  |     | 40  |     | 0          | ns   |
| T35    | AS Inactive to E high                                                                 | 0   |     | 0   |     | 0   |     | 0   |     | 0          | ns   |
| T36    | Address to Leading<br>Edge of Write                                                   | 20  |     | 20  |     | 25  |     | 30  |     | 0          | ns   |

NOTES: 8. ADi = any address line.

9. CSOI = any of the chip-select output signals coming through Port B (CSO-CS7) or through Port C (CS8-CS10).

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

11. Control signals  $\overline{RD}/E/\overline{DS}$  or  $\overline{WR}$  or R/W.

## **PSD301**



### **PSD301**



# **PSD301**



### **PSD301**



### **PSD301**



#### **PSD301**



### **PSD301**



#### **PSD301**



### **PSD301**

#### Figure 9. Chip-Select Output Timing



### **PSD301**



#### **PSD301**



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

#### Notes for Timing Diagrams

- 12. Direct PAD input = any of the following direct PAD input lines: CSI/A19 as transparent A19, RD/E, WR or R/W, transparent PC0–PC2, ALE and A11/AD11–A15/AD15 in non-multiplexed modes.
- Multiplexed inputs: any of the following inputs that are latched by the ALE (or AS): <u>A0/AD</u>0–A15/AD15, CSI/A19 as ALE dependent A19, ALE dependent PC0–PC2.
- <u>CSOi</u> = any of the chip-select output signals coming through Port B (<u>CS0–CS7</u>) or through Port C (<u>CS8–CS10</u>).
- 15. CSADOUT1, which internally enables the address transfer to Port A, should be derived only from direct PAD input signals, otherwise the address propagation delay is slowed down.
- 16. CSADIN and CSADOUT2, which internally enable the data-in or data-out transfers, respectively, can be derived from any combination of direct PAD inputs and multiplexed PAD inputs.
- 17. The write operation signals are included in the  $\overline{\text{CSOi}}$  expression.
- Multiplexed PAD inputs: any of the following PAD inputs that are latched by the ALE (or AS) in the multiplexed modes: A11/AD11-A15/AD15, CSI/A19 as ALE dependent A19, ALE dependent PC0-PC2.
- 19. CSOi product terms can include any of the PAD input signals except for reset and CSI.

# Field-programmable microcontroller peripheral

#### PSD301

| Pin<br>Capacitance <sup>20</sup> | Symbol | Parameter                                                    | Conditions             | <b>Typical<sup>21</sup></b> | Max | Unit |  |
|----------------------------------|--------|--------------------------------------------------------------|------------------------|-----------------------------|-----|------|--|
| Cin                              |        | Capacitance (for input pins only)                            | V <sub>IN</sub> = 0 V  | 4                           | 6   | pF   |  |
|                                  | COUT   | Capacitance (for input/output pins)                          | V <sub>OUT</sub> = 0 V | 8                           | 12  | pF   |  |
|                                  | CVPP   | Capacitance (for WR/V <sub>PP</sub> or R/W/V <sub>PP</sub> ) | V <sub>PP</sub> = 0 V  | 18                          | 25  | pF   |  |

NOTES: 20. This paramter is only sampled and is not 100% tested.

21. Typical values are for T<sub>A</sub> = 25°C and nominal supply voltages.



The PSD3XX and similar devices will erase with light sources having wavelengths shorter than 4000 Å. Although the erasure times will be much longer than with UV sources at 2537 Å, exposure to fluorescent light and sunlight eventually erases the

removed from the UV light source prior to

erasure.

PSD3XX device has all bits in the PAD and EPROM in the "1" or high state. The configuration bits are in the "0" or low state. The code, configuration, and PAD MAP data are loaded through the procedure of programming

**PSD301** 

| Pin<br>Assignments | Pin Name        | 44-Pin<br>PLCC/CLCC<br>Package | 52-Pin<br>PQFP Package |
|--------------------|-----------------|--------------------------------|------------------------|
|                    | BHE/PSEN        | 1                              | 46                     |
|                    | WR/VPP or R/W   | 2                              | 47                     |
|                    | RESET           | 3                              | 48                     |
|                    | PB7             | 4                              | 49                     |
|                    | PB6             | 5                              | 50                     |
|                    | PB5             | 6                              | 51                     |
|                    | PB4             | 7                              | 2                      |
|                    | PB3             | 8                              | 3                      |
|                    | PB2             | 9                              | 4                      |
|                    | PB1             | 10                             | 5                      |
|                    | PB0             | 11                             | 6                      |
|                    | GND             | 12                             | 7                      |
|                    | ALE or AS       | 13                             | 8                      |
|                    | PA7             | 14                             | 9                      |
|                    | PA6             | 15                             | 10                     |
|                    | PA5             | 16                             | 11                     |
|                    | PA4             | 17                             | 12                     |
|                    | PA3             | 18                             | 15                     |
|                    | PA2             | 19                             | 16                     |
|                    | PA1             | 20                             | 17                     |
|                    | PAO             | 21                             | 18                     |
|                    | RD/E            | 22                             | 19                     |
|                    | AD0/A0          | 23                             | 20                     |
|                    | AD1/A1          | 24                             | 21                     |
|                    | AD2/A2          | 25                             | 22                     |
|                    | AD3/A3          | 26                             | 23                     |
|                    | AD4/A4          | 27                             | 24                     |
|                    | AD5/A5          | 28                             | 25                     |
|                    | AD6/A6          | 29                             | 28                     |
|                    | AD7/A7          | 30                             | 29                     |
|                    | AD8/A8          | 31                             | 30                     |
|                    | AD9/A9          | 32                             | 31                     |
|                    | AD10/A10        | 33                             | 32                     |
|                    | GND             | 34                             | 33                     |
|                    | AD11/A11        | 35                             | 34                     |
|                    | AD12/A12        | 36                             | 35                     |
|                    | AD13/A13        | 37                             | 36                     |
|                    | AD14/A14        | 38                             | 37                     |
|                    | AD15/A15        | 39                             | 38                     |
|                    | PC0             | 40                             | 41                     |
|                    | PC1             | 40                             | 41                     |
|                    | PC2             | 42                             | 43                     |
|                    | A19/CSI         | 43                             | 43                     |
|                    | V <sub>cc</sub> | 43                             | 44                     |
|                    | •00             |                                | 40                     |

NOTE: 36. Pins 1, 13, 14, 26, 27, 39, 40, and 52 are No Connect.





| Ordering<br>Information | Part Number   | Spd.<br>(ns) | Package<br>Type            | Package<br>Drawing | Operating<br>Temperature<br>Range | Manufacturing<br>Procedure |
|-------------------------|---------------|--------------|----------------------------|--------------------|-----------------------------------|----------------------------|
|                         | PSD301-90 A   | 90           | 44-pin PLCC                | J2                 | Commercial                        | Standard                   |
|                         | PSD301-90 KA  | 90           | 44-pin CLCC                | L4                 | Commercial                        | Standard                   |
|                         | PSD301-12 A   | 120          | 44-pin PLCC                | J2                 | Commercial                        | Standard                   |
|                         | PSD301-12 KA  | 120          | 44-pin CLCC                | L4                 | Commercial                        | Standard                   |
|                         | PSD301-12 B   | 120          | 0 52-pin PQFP Q2 Commercia | Q2 Commercial      | Q2 Com                            | Standard                   |
|                         | PSD301-15 A   | 150          | 44-pin PLCC                | J2                 | Commercial                        | Standard                   |
|                         | PSD301-15I A  | 150          | 44-pin PLCC                | J2                 | Industrial                        | Standard                   |
|                         | PSD301-15 KA  | 150          | 44-pin CLCC                | L4                 | Commercial                        | Standard                   |
|                         | PSD301-15I KA | 150          | 44-pin CLCC                | L4                 | Industrial                        | Standard                   |
|                         | PSD301-15 B   | 150          | 52-pin PQFP                | Q2                 | Commercial                        | Standard                   |
|                         | PSD301-15I B  | 150          | 52-pin PQFP                | Q2                 | Industrial                        | Standard                   |
|                         | PSD301-20 A   | 200          | 44-pin PLCC                | J2                 | Commercial                        | Standard                   |
|                         | PSD301-20I A  | 200          | 44-pin PLCC                | J2                 | Industrial                        | Standard                   |
|                         | PSD301-20 KA  | 200          | 44-pin CLCC                | L4                 | Commercial                        | Standard                   |
|                         | PSD301-20I KA | 200          | 44-pin CLCC                | L4                 | Industrial                        | Standard                   |
|                         | PSD301-20 B   | 200          | 52-pin PQFP                | Q2                 | Commercial                        | Standard                   |
|                         | PSD301-20I B  | 200          | 52-pin PQFP                | Q2                 | Industrial                        | Standard                   |

**Key Features** 

- Single Chip Programmable Peripheral for Microcontroller-based Applications
- 19 Individually Configurable I/O pins that can be used as:
- Microcontroller I/O port expansion
- --- Programmable Address Decoder (PAD) I/O
- Latched address output
- Open drain or CMOS
- Two Programmable Arrays (PAD A and PAD B)
- Total of 40 Product Terms and up to 16 Inputs and 24 Outputs
- Address Decoding up to 1 MB
- Logic replacement
- "No Glue" Microcontroller Chip-Set

 Built-in address latches for multiplexed address/data bus

- Non-multiplexed address/data bus mode
- 8-bit data bus width
- ALE and Reset polarity programmable
- Selectable modes for read and write control bus as RD/WR or R/W/E
- PSEN pin for 8051 users
- 256 Kbits of UV EPROM
- Configurable as 32K x 8
- Divides into 8 equal mappable blocks for optimized mapping
- Block resolution is 4K x 8
- 120 ns EPROM access time, including input latches and PAD address decoding.

- 16 Kbit Static RAM
- Configurable as 2K x 8
- 120 ns SRAM access time, including input latches and PAD address decoding
- Address/Data Track Mode
- Enables easy Interface to Shared Resources (e.g., Mail Box SRAM) with other Microcontrollers or a Host Processor
- Built-In Security
- Locks the PSD311 and PAD Decoding Configuration
- Available in a Choice of Packages
- 44 Pin PLCC and CLCC
- 52 Pin PQFP
- 44 Pin CPGA
- Simple Menu-Driven Software: Configure the PSD311 on an IBM PC

Field-programmable microcontroller peripheral

# Preliminary specification

**PSD311** 

### Field-programmable microcontroller peripheral

| Security<br>Mode | Security Mode in the PSD3XX locks the<br>contents of the PAD A , PAD B and all the<br>configuration bits. The EPROM, SRAM,<br>and I/O contents can be accessed only<br>through the PAD. The Security Mode can<br>be set by the MAPLE or Programming         | software. In window packages, the mode is<br>erasable through UV full part erasure. In<br>the security mode, the PSD3XX contents<br>cannot be copied on a programmer.                                                                                                                                |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CMIser-Bit       | The CMiser-Bit provides a programmable<br>option for power-sensitive applications that<br>require further reduction in power<br>consumption. The CMiser-Bit (CMiser = 1)<br>in the Maple portion of the PSD3XX sytem<br>development software can be used to | In the default mode, or if the PSD3XX is<br>configured without programming the<br>CMiser-Bit (CMiser = 0), the device<br>operates at specified speed and power<br>rating as specified in the A.C. and D.C.<br>Characteristics.                                                                       |
|                  | reduce power consumption. The CMiser-Bit<br>turns off the EPROM blocks in the PSD3XX<br>whenever the EPROM is not accessed,<br>thereby reducing the active current<br>consumed by the PSD3XX.                                                               | However, if the CMiser-Bit is programmed<br>(CMiser = 1), the device consumes even<br>lower current, and is reflected in the data<br>sheet. This mode has an adder in<br>propagation delay in T5, T6, and T7<br>parameters in the A.C. Characteristics, and<br>should be added to compute worst-case |

| Absolute             |
|----------------------|
| Maximum              |
| Ratings <sup>1</sup> |

| Symbol           | Parameter                     | Condition           | Min   | Max   | Unit |
|------------------|-------------------------------|---------------------|-------|-------|------|
| т                | Starage Temperature           | CERDIP              | - 65  | + 150 | °C   |
| T <sub>STG</sub> | Storage Temperature           | PLASTIC             | - 65  | + 125 | °C   |
|                  | Voltage on any Pin            | With Respect to GND | - 0.6 | +7    | v    |
| V <sub>PP</sub>  | Programming<br>Supply Voltage | With Respect to GND | - 0.6 | + 14  | v    |
| V <sub>cc</sub>  | Supply Voltage                | With Respect to GND | - 0.6 | +7    | v    |
|                  | ESD Protection                |                     |       | >2000 | V    |

timing requirements in the application.

NOTE: 1. 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 theses or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to Absolute Maximum Rating conditions for extended periods of time may affect device reliability.

| Operating<br>Range | Range      | Temperature      | V <sub>CC</sub> | V <sub>CC</sub> Tolerance |       |       |  |  |  |
|--------------------|------------|------------------|-----------------|---------------------------|-------|-------|--|--|--|
|                    | J          |                  | - 00            | -12                       | -15   | -20   |  |  |  |
|                    | Commercial | 0° C to +70°C    | + 5 V           | ± 10%                     | ± 10% | ± 10% |  |  |  |
|                    | Industrial | -40° C to +80°C  | + 5 V           |                           | ± 10% | ± 10% |  |  |  |
|                    | Military   | -55° C to +125°C | + 5 V           |                           |       | ± 10% |  |  |  |

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

DC

**Characteristics** 

# Field-programmable microcontroller peripheral

**PSD311** 

| Symbol           | Parameter                                                                             | Conditions                                          |     |      |      | CMiser = 1<br>Subtract: |     |                                             |     |
|------------------|---------------------------------------------------------------------------------------|-----------------------------------------------------|-----|------|------|-------------------------|-----|---------------------------------------------|-----|
|                  |                                                                                       |                                                     | Min | Тур  | Max  | Min                     | Тур | Max                                         | Uni |
| V <sub>OL</sub>  | Output Low                                                                            | l <sub>OL</sub> = 20 μA<br>V <sub>CC</sub> = 4.5 V  |     | 0.01 | 0.1  |                         |     |                                             | v   |
| VOL              | Voltage                                                                               | l <sub>OL</sub> = 8 mA<br>V <sub>CC</sub> = 4.5 V   |     | 0.15 | 0.45 |                         |     |                                             | v   |
| V <sub>OH</sub>  | Output High                                                                           | I <sub>OH</sub> = -20 μA<br>V <sub>CC</sub> = 4.5 V | 4.4 | 4.49 |      |                         |     |                                             | v   |
| VOH              | Voltage                                                                               | l <sub>OH</sub> = -2 mA<br>V <sub>CC</sub> = 4.5 V  | 2.4 | 3.9  |      |                         |     |                                             | v   |
| 1                | V <sub>CC</sub> Standby<br>Current (CMQS)                                             | Comm'l                                              |     | 50   | 100  |                         |     |                                             | μA  |
| ISB1             | (Notes 2 and 4)                                                                       | Ind/Mil                                             |     | 75   | 150  |                         |     |                                             | μA  |
|                  |                                                                                       | Comm'l<br>(Note 6)                                  |     | 16   | 35   | i                       | 7   | 10                                          | mA  |
| I <sub>CC1</sub> | Active Current<br>(CMOS) (No<br>Internal Memory<br>Block Selected)<br>(Notes 2 and 5) | Comm'l<br>(Note 7)                                  |     | 28   | 50   |                         | 7   | 10                                          | mA  |
| .001             |                                                                                       | Ind/Mil<br>(Note 6)                                 |     | 16   | 45   |                         | 7   | 10                                          | mA  |
|                  | (                                                                                     | Ind/Mil<br>(Note 7)                                 |     | 28   | 60   |                         | 7   | 10                                          | mA  |
|                  |                                                                                       | Comm'l<br>(Note 6)                                  |     | 16   | 35   |                         | 0   | 0                                           | mA  |
| lass             | Active Current<br>(CMOS) (EPROM                                                       | Comm'l<br>(Note 7)                                  |     | 28   | 50   |                         | 0   | 0                                           | mA  |
| ICC2             | Block Selected)<br>(Notes 2 and 5)                                                    | Ind/Mil<br>(Note 6)                                 |     | 16   | 45   |                         | 0   | 0                                           | mA  |
|                  |                                                                                       | Ind/Mil<br>(Note 7)                                 |     | 28   | 60   |                         | 0   | t:<br>Max<br>10<br>10<br>10<br>10<br>0<br>0 | mA  |
|                  |                                                                                       | Comm'l<br>(Note 6)                                  |     | 47   | 80   |                         | 7   | 10                                          | mA  |
| laas             | Active Current<br>(CMOS) (SRAM                                                        | Comm'l<br>(Note 7)                                  |     | 59   | 95   |                         | 7   | 10                                          | mA  |
| ICC3             | Block Selected (Notes 2 and 5)                                                        | Ind/Mil<br>(Note 6)                                 |     | 47   | 100  |                         | 7   | 10                                          | mA  |
|                  |                                                                                       | Ind/Mil<br>(Note 7)                                 |     | 59   | 115  |                         | 7   | 10                                          | mA  |
| l <sub>LI</sub>  | Input Leakage<br>Current                                                              | V <sub>IN</sub> = 5.5 V<br>or GND                   | -1  | ±0.1 | 1    |                         |     |                                             | μA  |
| l <sub>LO</sub>  | Output Leakage<br>Current                                                             | V <sub>OUT</sub> = 5.5 V<br>or GND                  | -10 | ±5   | 10   |                         |     |                                             | μA  |

NOTES: 2. CMOS inputs: GND ± 0.3 V or V<sub>CC</sub> ± 0.3V.
3. <u>TTL</u> inputs: V<sub>IL</sub> ≤ 0.8 V, V<sub>IH</sub> ≥ 2.0 V.
4. CSI/A19 is high and the part is in a power-down configuration mode.
5. Add 3.0 mA/MHz for AC power component (power = AC + DC).
6. Ten (10) PAD product terms active. (Add 380 μA per product term, typical, or 480 μA per product term maximum
7. Forty-one (41) PAD product terms active.

# **PSD311**

# AC Characteristics

| Sumbal |                                                                   | -90 |     | -12 |     | -15 |     | -20 |     | CMiser = 1 |      |
|--------|-------------------------------------------------------------------|-----|-----|-----|-----|-----|-----|-----|-----|------------|------|
| Symbol | Parameter                                                         | Min | Max | Min | Max | Min | Max | Min | Max | Add:       | Unit |
| T1     | ALE or AS Pulse Width                                             | 20  |     | 30  |     | 40  |     | 50  |     | 0          | ns   |
| T2     | Address Set-up Time                                               | 5   |     | 9   |     | 12  |     | 15  |     | 0          | ns   |
| T3     | Address Hold Time                                                 | 8   |     | 13  |     | 15  |     | 25  |     | 0          | ns   |
| T4     | Leading Edge of Read to Data Active                               | 0   |     | 0   |     | 0   |     | 0   |     | 0          | ns   |
| Т5     | ALE Valid to Data Valid                                           |     | 100 |     | 140 |     | 170 |     | 200 | 10         | ns   |
| Т6     | Address Valid to Data Valid                                       |     | 90  |     | 120 |     | 150 |     | 200 | 10         | ns   |
| T7     | CSI Active to Data Valid                                          |     | 100 |     | 150 |     | 160 |     | 200 | 15         | ns   |
| Т8     | Leading Edge of Read<br>to Data Valid                             |     | 32  |     | 38  |     | 55  |     | 60  | 0          | ns   |
| Т9     | Read Data Hold Time                                               | 0   |     | 0   |     | 0   |     | 0   |     | 0          | ns   |
| T10    | Trailing Edge of Read to<br>Data High-Z                           |     | 35  |     | 35  |     | 40  |     | 45  | 0          | ns   |
| T11    | Trailing Edge of ALE or AS to Leading Edge of Write               | 0   |     | 0   |     | 0   |     | 0   |     | 0          | ns   |
| T12    | RD, E, PSEN, or DS<br>Pulse Width                                 | 40  |     | 45  |     | 60  |     | 75  |     | 0          | ns   |
| T12A   | WR Pulse Width                                                    | 20  |     | 25  |     | 35  |     | 45  |     | 0          | ns   |
| T13    | Trailing Edge of Write or<br>Read to Leading Edge<br>of ALE or AS | 0   |     | 0   |     | 0   |     | 0   |     | 0          | ns   |
| T14    | Address Valid to Trailing<br>Edge of Write                        | 90  |     | 120 |     | 150 |     | 200 |     | 0          | ns   |
| T15    | CSI Active to Trailing Edge<br>of Write                           | 100 |     | 130 |     | 160 |     | 200 |     | 0          | ns   |
| T16    | Write Data Set-up Time                                            | 20  |     | 25  |     | 30  |     | 40  |     | 0          | ns   |
| T17    | Write Data Hold Time                                              | 5   |     | 5   |     | 10  |     | 15  |     | 0          | ns   |
| T18    | Port to Data Out Valid<br>Propagation Delay                       |     | 30  |     | 30  |     | 35  |     | 45  | 0          | ns   |
| T19    | Port Input Hold Time                                              | 0   |     | 0   |     | 0   |     | 0   |     | 0          | ns   |
| T20    | Trailing Edge of Write<br>to Port Output Valid                    | 40  |     | 40  |     | 50  |     | 60  |     | 0          | ns   |
| T21    | ADi or Control to $\overline{CSOi}$<br>Valid                      | 6   | 25  | 6   | 30  | 6   | 35  | 5   | 45  | 0          | ns   |
| T22    | ADi or Control to CSOi<br>Invalid                                 | 5   | 25  | 5   | 30  | 4   | 35  | 4   | 45  | 0          | ns   |

#### **PSD311**

#### AC Characteristics (Cont.)

|        | <b></b>                                                                               | -9  | 0   | -1  | 2   | -15 |     | -20 |     | CMiser = 1 |      |
|--------|---------------------------------------------------------------------------------------|-----|-----|-----|-----|-----|-----|-----|-----|------------|------|
| Symbol | Parameter                                                                             | Min | Max | Min | Max | Min | Max | Min | Max | Add:*      | Unit |
| T23    | Track Mode Address<br>Propagation Delay:<br>CSADOUT1 Already True                     |     | 22  |     | 22  |     | 22  |     | 28  | 0          | ns   |
| T23A   | Track Mode Address<br>Propagation Delay:<br>CSADOUT1 Becomes<br>True During ALE or AS |     | 33  |     | 33  |     | 40  |     | 50  | 0          | ns   |
| T24    | Track Mode Trailing Edge<br>of ALE or AS to Address<br>High-Z                         |     | 32  |     | 32  |     | 35  |     | 40  | 0          | ns   |
| T25    | Track Mode Read<br>Propagation Delay                                                  |     | 29  |     | 29  |     | 29  |     | 35  | 0          | ns   |
| T26    | Track Mode Read<br>Hold Time                                                          | 11  | 29  | 11  | 29  | 10  | 29  | 10  | 35  | 0          | ns   |
| T27    | Track Mode Write Cycle,<br>Data Propagation Delay                                     |     | 20  |     | 20  |     | 20  |     | 30  | 0          | ns   |
| T28    | Track Mode Write<br>Cycle, Write to Data<br>Propagation Delay                         | 8   | 30  | 8   | 30  | 7   | 40  | 7   | 55  | 0          | ns   |
| T29    | Hold Time of Port A<br><u>Valid</u> During Write<br>CSOi Trailing Edge                | 2   |     | 2   |     | 2   |     | 2   |     | 0          | ns   |
| T30    | CSI Active to CSOi Active                                                             | 9   | 40  | 9   | 45  | 9   | 45  | 8   | 60  | 0          | ns   |
| T31    | CSI Inactive to CSOi<br>Inactive                                                      | 9   | 40  | 9   | 45  | 9   | 45  | 8   | 60  | 0          | ns   |
| T32    | Direct PAD Input as<br>Hold Time                                                      | 10  |     | 10  |     | 12  |     | 15  |     | 0          | ns   |
| T33    | R/W Active to E High                                                                  | 20  |     | 20  |     | 30  |     | 40  |     | 0          | ns   |
| T34    | E End to R/W                                                                          | 20  |     | 20  |     | 30  |     | 40  |     | 0          | ns   |
| T35    | AS Inactive to E high                                                                 | 0   |     | 0   |     | 0   |     | 0   |     | 0          | ns   |
| Т36    | Address to Leading<br>Edge of Write                                                   | 20  |     | 20  |     | 25  |     | 30  |     | 0          | ns   |

NOTES: 8. ADi = any address line.

9. CSOi = any of the chip-select output signals coming through Port B (CSO-CS7) or through Port C (CS8-CS10).

10. Direct PAD input = any of the following direct PAD input lines: CSI/A19 as transparent A19, RD/E/DS, WR or R/W, transparent PC0–PC2, ALE (or AS). 11. Control signals RD/E/DS or WR or R/W.

PSD311



### **PSD311**



# PSD311



# **PSD311**





# **PSD311**

#### Figure 5. Chip-Select Output Timing



# **PSD311**



#### **PSD311**



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

#### Notes for Timing Diagrams

- 12. Direct PAD input = any of the following direct PAD input lines: CSI/A19 as transparent A19, RD/E, WR or RW, transparent PC0–PC2, ALE in non-multiplexed modes.
- Multiplexed inputs: any of the following inputs that are latched by the ALE (or AS): <u>A0/AD0–A15/AD15, CSI/A19 as ALE dependent A19, ALE dependent PC0–PC2.</u>
- 14. CSOi = any of the chip-select output signals coming through Port B (CS0–CS7) or through Port C (CS8–CS10).
- 15. CSADOUT1, which internally enables the address transfer to Port A, should be derived only from direct PAD input signals, otherwise the address propagation delay is slowed down.
- 16. CSADIN and CSADOUT2, which internally enable the data-in or data-out transfers, respectively, can be derived from any combination of direct PAD inputs and multiplexed PAD inputs.
- 17. The write operation signals are included in the CSOi expression.

 Multiplexed PAD inputs: any of the following PAD inputs that are latched by the ALE (or AS) in the multiplexed modes: A11/AD11–A15/AD15, CSI/A19 as ALE dependent A19, ALE dependent PC0–PC2.

19. CSOi product terms can include any of the PAD input signals except for reset and CSI.

# Field-programmable microcontroller peripheral

### **PSD311**

| Pin<br>Capacitance <sup>20</sup> | Symbol | Parameter                                                    | Conditions             | Typical <sup>21</sup> | Max | Unit |
|----------------------------------|--------|--------------------------------------------------------------|------------------------|-----------------------|-----|------|
| oapachanoc                       | CIN    | Capacitance (for input pins only)                            | $V_{IN} = 0 V$         | 4                     | 6   | pF   |
|                                  | COUT   | Capacitance (for input/output pins)                          | V <sub>OUT</sub> = 0 V | 8                     | 12  | pF   |
|                                  | CVPP   | Capacitance (for WR/V <sub>PP</sub> or R/W/V <sub>PP</sub> ) | V <sub>PP</sub> = 0 V  | 18                    | 25  | pF   |

NOTES: 20. This paramter is only sampled and is not 100% tested.

21. Typical values are for T<sub>A</sub> = 25°C and nominal supply voltages.



with light sources having wavelengths shorter than 4000 Å. Although the erasure times will be much longer than with UV sources at 2537 Å, exposure to fluorescent light and sunlight eventually erases the

programming

**PSD311** 

| Pin<br>Assignments | Pin Name                  | 44-Pin<br>PLCC/CLCC<br>Package | 52-Pin<br>PQFP Package |
|--------------------|---------------------------|--------------------------------|------------------------|
|                    | PSEN                      | 1                              | 46                     |
|                    | WR/V <sub>PP</sub> or R/W | 2                              | 47                     |
|                    | RESET                     | 3                              | 48                     |
|                    | PB7                       | 4                              | 49                     |
|                    | PB6                       | 5                              | 50                     |
|                    | PB5                       | 6                              | 51                     |
|                    | PB4                       | 7                              | 2                      |
|                    | PB3                       | 8                              | 3                      |
|                    | PB2                       | 9                              | 4                      |
|                    | PB1                       | 10                             | 5                      |
|                    | PB0                       | 11                             | 6                      |
|                    | GND                       | 12                             | 7                      |
|                    | ALE or AS                 | 13                             | 8                      |
|                    | PA7                       | 14                             | 9                      |
|                    | PA6                       | 15                             | 10                     |
|                    | PA5                       | 16                             | 11                     |
|                    | PA4                       | 17                             | 12                     |
|                    | PA3                       | 18                             | 15                     |
|                    | PA2                       | 19                             | 16                     |
|                    | PA1                       | 20                             | 17                     |
|                    | PAO                       | 21                             | 18                     |
|                    | RD/E                      | 22                             | 19                     |
|                    | AD0/A0                    | 23                             | 20                     |
|                    | AD1/A1                    | 24                             | 21                     |
|                    | AD2/A2                    | 25                             | 22                     |
|                    | AD3/A3                    | 26                             | 23                     |
|                    | AD4/A4                    | 27                             | 24                     |
|                    | AD5/A5                    | 28                             | 25                     |
|                    | AD6/A6                    | 29                             | 28                     |
|                    | AD7/A7                    | 30                             | 29                     |
|                    | A8                        | 31                             | 30                     |
|                    | A9                        | 32                             | 31                     |
|                    | A10                       | 33                             | 32                     |
|                    | GND                       | 34                             | 33                     |
|                    | A11                       | 35                             | 34                     |
|                    | A12                       | 36                             | 35                     |
|                    | A13                       | 37                             | 36                     |
|                    | A14                       | 38                             | 37                     |
|                    | A15                       | 39                             | 38                     |
|                    | PC0                       | 40                             | 41                     |
|                    | PC1                       | 41                             | 42                     |
|                    | PC2                       | 42                             | 43                     |
|                    | A19/CSI                   | 43                             | 44                     |
|                    | V <sub>cc</sub>           | 44                             | 45                     |
|                    |                           |                                |                        |

NOTE: 36. Pins 1, 13, 14, 26, 27, 39, 40, and 52 are No Connect.



#### Preliminary specification

# Field-programmable microcontroller peripheral



| Ordering<br>Information | Part Number   | Spd.<br>(ns) | Package<br>Type | Package<br>Drawing | Operating<br>Temperature<br>Range | Manufacturing<br>Procedure |
|-------------------------|---------------|--------------|-----------------|--------------------|-----------------------------------|----------------------------|
|                         | PSD311-90 A   | 90           | 44-pin PLCC     | J2                 | Commercial                        | Standard                   |
|                         | PSD311-90 KA  | 90           | 44-pin CLCC     | L4                 | Commercial                        | Standard                   |
|                         | PSD311-12 A   | 120          | 44-pin PLCC     | J2                 | Commercial                        | Standard                   |
|                         | PSD311-12 KA  | 120          | 44-pin CLCC     | L4                 | Commercial                        | Standard                   |
|                         | PSD311-12 B   | 120          | 52-pin PQFP     | Q2                 | Commercial                        | Standard                   |
|                         | PSD311-15 A   | 150          | 44-pin PLCC     | J2                 | Commercial                        | Standard                   |
|                         | PSD311-15I A  | 150          | 44-pin PLCC     | J2                 | Industrial                        | Standard                   |
|                         | PSD311-15 KA  | 150          | 44-pin CLCC     | Ľ4                 | Commercial                        | Standard                   |
|                         | PSD311-15I KA | 150          | 44-pin CLCC     | L4                 | Industrial                        | Standard                   |
|                         | PSD311-15 B   | 150          | 52-pin PQFP     | Q2                 | Commercial                        | Standard                   |
|                         | PSD311-15I B  | 150          | 52-pin PQFP     | Q2                 | Industrial                        | Standard                   |
|                         | PSD311-20 A   | 200          | 44-pin PLCC     | J2                 | Commercial                        | Standard                   |
|                         | PSD311-20I A  | 200          | 44-pin PLCC     | J2 -               | Industrial                        | Standard                   |
|                         | PSD311-20 KA  | 200          | 44-pin CLCC     | L4                 | Commercial                        | Standard                   |
|                         | PSD311-20I KA | 200          | 44-pin CLCC     | L4                 | Industrial                        | Standard                   |
|                         | PSD311-20 B   | 200          | 52-pin PQFP     | Q2                 | Commercial                        | Standard                   |
|                         | PSD311-20I B  | 200          | 52-pin PQFP     | Q2                 | Industrial                        | Standard                   |

**PSD302** 

# Field-programmable microcontroller peripheral

# Key Features

- Single Chip Programmable Peripheral for Microcontroller-based Applications
- 19 Individually Configurable I/O pins that can be used as:
- Microcontroller I/O port expansion
- Programmable Address Decoder (PAD) I/O
- Latched address output
- Open drain or CMOS
- Two Programmable Arrays (PAD A & PAD B)
- Total of 40 Product Terms and up to 16 Inputs and 24 Outputs
- Direct Address Decoding up to 1 Meg address space and up to 16 Meg with paging
- Logic replacement
- Glue" Microcontroller Chip-Set
- Built-in address latches for multiplexed address/data bus
- Non-multiplexed address/data bus mode
- Selectable 8 or 16 bit data bus width
- ALE and Reset polarity programmable
- Selectable modes for read and write control bus as RD/WR, R/W/E, or R/W/DS
- BHE pin for byte select in 16-bit mode
- PSEN pin for 8051 users
- Built-In Page Logic
- To Expand the Address Space of Microcontrollers with Limited Address Space Capabilities
- Up to 16 pages

- 512 Kbits of UV EPROM
- Configurable as 64K x 8 or as 32K x 16
- Divides into 8 equal mappable blocks for optimized mapping
- Block resolution is 8K x 8 or 4K x 16
- 120 ns EPROM access time, including input latches and PAD address decoding.
- 16 Kbit Static RAM
- Configurable as 2K x 8 or as 1K x 16
- 120 ns SRAM access time, including input latches and PAD address decoding
- Address/Data Track Mode
- Enables easy Interface to Shared Resources (e.g., Mail Box SRAM) with other Microcontrollers or a Host Processor
- CMiser-Bit
- Programmable option to further reduce power consumption
- Built-In Security
- Locks the PSD302 and PAD Decoding Configuration
- Available in a Choice of Packages
- 44 Pin PLCC and CLCC
- 52 Pin PQFP
- Simple Menu-Driven Software: Configure the PSD302 on an IBM PC
- Pin and Function Compatible with the PSD301

**PSD302** 

# Field-programmable microcontroller peripheral

| Security<br>Mode | Security Mode in the PSD3XX locks the<br>contents of the PAD A, PAD B and all the<br>configuration bits. The EPROM, SRAM,<br>and I/O contents can be accessed only<br>through the PAD. The Security Mode can<br>be set by the MAPLE or Programming          | software. In window packages, the mode is<br>erasable through UV full part erasure. In<br>the security mode, the PSD3XX contents<br>cannot be copied on a programmer.                                                                                                                                |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CMIser-Bit       | The CMiser-Bit provides a programmable<br>option for power-sensitive applications that<br>require further reduction in power<br>consumption. The CMiser-Bit (CMiser = 1)<br>in the Maple portion of the PSD3XX sytem<br>development software can be used to | In the default mode, or if the PSD3XX is<br>configured without programming the<br>CMiser-Bit (CMiser = 0), the device<br>operates at specified speed and power<br>rating as specified in the A.C. and D.C.<br>Characteristics.                                                                       |
|                  | reduce power consumption. The CMiser-Bit<br>turns off the EPROM blocks in the PSD3XX<br>whenever the EPROM is not accessed,<br>thereby reducing the active current<br>consumed by the PSD3XX.                                                               | However, if the CMiser-Bit is programmed<br>(CMiser = 1), the device consumes even<br>lower current, and is reflected in the data<br>sheet. This mode has an adder in<br>propagation delay in T5, T6, and T7<br>parameters in the A.C. Characteristics, and<br>should be added to compute worst-case |

| Absolute             |
|----------------------|
| Maximum              |
| Ratings <sup>1</sup> |

| Symbol           | Parameter                     | Condition           | Min   | Max   | Unit |  |
|------------------|-------------------------------|---------------------|-------|-------|------|--|
| Ŧ                | Storogo Tomporoturo           | CERDIP              | - 65  | + 150 | °C   |  |
| T <sub>STG</sub> | Storage Temperature           | PLASTIC             | - 65  | + 125 | °C   |  |
|                  | Voltage on any Pin            | With Respect to GND | - 0.6 | + 7   | ۷    |  |
| V <sub>PP</sub>  | Programming<br>Supply Voltage | With Respect to GND | - 0.6 | + 14  | v    |  |
| V <sub>cc</sub>  | Supply Voltage                | With Respect to GND | - 0.6 | + 7   | ٧    |  |
|                  | ESD Protection                |                     |       | >2000 | ٧    |  |

timing requirements in the application.

NOTE: 1. 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 theses or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to Absolute Maximum Rating conditions for extended periods of time may affect device reliability.

| Operating<br>Range | Range      | Temperature      | V <sub>CC</sub> | V <sub>CC</sub> Tolerance |       |       |  |  |
|--------------------|------------|------------------|-----------------|---------------------------|-------|-------|--|--|
| nanyc              | nunge      | poraare          | - 66            | -12                       | -15   | -20   |  |  |
|                    | Commercial | 0° C to +70°C    | + 5 V           | ± 10%                     | ± 10% | ± 10% |  |  |
|                    | Industrial | -40° C to +80°C  | + 5 V           |                           | ± 10% | ± 10% |  |  |
|                    | Military   | -55° C to +125°C | + 5 V           |                           |       | ± 10% |  |  |

| Recommended<br>Operating | Symbol          | Parameter                | Conditions                         | Min | Тур | Max | Unit |
|--------------------------|-----------------|--------------------------|------------------------------------|-----|-----|-----|------|
| Conditions               | V <sub>cc</sub> | Supply Voltage           | All Speeds                         | 4.5 | 5   | 5.5 | V    |
| VUILLIUIU                | VIH             | High-level Input Voltage | V <sub>CC</sub> = 4.5 V to 5.5 V   | 2   |     |     | V    |
|                          | VIL             | Low-level Input Voltage  | $V_{CC} = 4.5 V \text{ to } 5.5 V$ | 0   |     | 0.8 | V    |

DC

**Characteristics** 

# Field-programmable microcontroller peripheral

#### **PSD302**

| Symbol           | Parameter                                                                             | Conditions                                          |     |      |      | CMiser = 1<br>Subtract: |     |                                |     |
|------------------|---------------------------------------------------------------------------------------|-----------------------------------------------------|-----|------|------|-------------------------|-----|--------------------------------|-----|
|                  |                                                                                       |                                                     | Min | Тур  | Max  | Min                     | Тур | Max                            | Uni |
| V <sub>OL</sub>  | Output Low                                                                            | l <sub>OL</sub> = 20 μA<br>V <sub>CC</sub> = 4.5 V  |     | 0.01 | 0.1  |                         |     |                                | v   |
| VOL              | Voltage                                                                               | l <sub>OL</sub> = 8 mA<br>V <sub>CC</sub> = 4.5 V   |     | 0.15 | 0.45 |                         |     |                                | v   |
| V <sub>он</sub>  | Output High                                                                           | I <sub>OH</sub> = -20 μA<br>V <sub>CC</sub> = 4.5 V | 4.4 | 4.49 |      |                         |     | 10<br>10<br>10<br>10<br>0<br>0 | v   |
| €ОН              | Voltage                                                                               | I <sub>OH</sub> = -2 mA<br>V <sub>CC</sub> = 4.5 V  | 2.4 | 3.9  |      |                         |     |                                | v   |
| 1                | V <sub>CC</sub> Standby<br>Current (CMOS)                                             | Comm'l                                              |     | 50   | 100  |                         |     |                                | μΑ  |
| I <sub>SB1</sub> | (Notes 2 and 4)                                                                       | Ind/Mil                                             |     | 75   | 150  |                         |     |                                | μA  |
|                  | _                                                                                     | Comm'l<br>(Note 6)                                  |     | 16   | 35   |                         | 7   | 10                             | mA  |
| I <sub>CC1</sub> | Active Current<br>(CMOS) (No<br>Internal Memory<br>Block Selected)<br>(Notes 2 and 5) | Comm'l<br>(Note 7)                                  |     | 28   | 50   |                         | 7   | 10                             | mA  |
|                  |                                                                                       | Ind/Mil<br>(Note 6)                                 |     | 16   | 45   |                         | 7   | 10                             | mA  |
|                  | (                                                                                     | Ind/Mil<br>(Note 7)                                 |     | 28   | 60   |                         | 7   | 10                             | mA  |
|                  |                                                                                       | Comm'l<br>(Note 6)                                  |     | 16   | 35   |                         | 0   | 0                              | mA  |
| I <sub>CC2</sub> | Active Current<br>(CMOS) (EPROM                                                       | Comm'l<br>(Note 7)                                  |     | 28   | 50   |                         | 0   | 0                              | mA  |
| 1002             | Block Selected)<br>(Notes 2 and 5)                                                    | Ind/Mil<br>(Note 6)                                 |     | 16   | 45   |                         | 0   | 0                              | mA  |
|                  |                                                                                       | Ind/Mil<br>(Note 7)                                 |     | 28   | 60   |                         | 0   | 0                              | mA  |
|                  |                                                                                       | Comm'l<br>(Note 6)                                  |     | 47   | 80   |                         | 7   | 10                             | mA  |
| loss             | Active Current<br>(CMOS) (SRAM                                                        | Comm'l<br>(Note 7)                                  |     | 59   | 95   |                         | 7   | 10                             | mA  |
| I <sub>CC3</sub> | Block Selected<br>(Notes 2 and 5)                                                     | Ind/Mil<br>(Note 6)                                 |     | 47   | 100  |                         | 7   | 10                             | mA  |
|                  |                                                                                       | Ind/Mil<br>(Note 7)                                 |     | 59   | 115  |                         | 7   | 10                             | mA  |
| I <sub>LI</sub>  | Input Leakage<br>Current                                                              | V <sub>IN</sub> = 5.5 V<br>or GND                   | -1  | ±0.1 | 1    |                         |     |                                | μA  |
| ILO              | Output Leakage<br>Current                                                             | V <sub>OUT</sub> = 5.5 V<br>or GND                  | -10 | ±5   | 10   |                         |     |                                | μA  |

NOTES: 2.CMOS inputs:  $GND \pm 0.3$  V or  $V_{CC} \pm 0.3$ V.3. $\underline{TTL}$  inputs:  $V_{IL} \leq 0.8$  V,  $V_{IH} \geq 2.0$  V.4. $\underline{CSI}/A19$  is high and the part is in a power-down configuration mode.5.Add 3.0 mA/MHz for AC power component (power = AC + DC).

6. Ten (10) PAD product terms active. (Add 380 μA per product term, typical, or 480 μA per product term maximum 7. Forty-one (41) PAD product terms active.

### **PSD302**

### **AC Characteristics**

|        |                                                                   | -9  | 10  | -1  | 2   | -15 |     | -20 |     | CMiser = 1 |      |
|--------|-------------------------------------------------------------------|-----|-----|-----|-----|-----|-----|-----|-----|------------|------|
| Symbol | Parameter                                                         | Min | Max | Min | Max | Min | Max | Min | Max | Add:       | Unit |
| T1     | ALE or AS Pulse Width                                             | 20  |     | 30  |     | 40  |     | 50  |     | 0          | ns   |
| T2     | Address Set-up Time                                               | 5   |     | 9   |     | 12  |     | 15  |     | 0          | ns   |
| T3     | Address Hold Time                                                 | 8   |     | 9   |     | 12  |     | 15  |     | 0          | ns   |
| T4     | Leading Edge of Read to Data Active                               | 0   |     | 0   |     | 0   |     | 0   |     | 0          | ns   |
| T5     | ALE Valid to Data Valid                                           |     | 100 |     | 130 |     | 160 |     | 200 | 10         | ns   |
| T6     | Address Valid to Data Valid                                       |     | 90  |     | 120 |     | 150 |     | 200 | 10         | ns   |
| T7     | CSI Active to Data Valid                                          |     | 100 |     | 130 |     | 160 |     | 200 | 15         | ns   |
| T8     | Leading Edge of Read to Data Valid                                |     | 32  |     | 38  |     | 55  |     | 60  | 0          | ns   |
| T9     | Read Data Hold Time                                               | 0   |     | 0   |     | 0   |     | 0   |     | 0          | ns   |
| T10    | Trailing Edge of Read to<br>Data High-Z                           |     | 32  |     | 32  |     | 35  |     | 40  | 0          | ns   |
| T11    | Trailing Edge of ALE or AS to Leading Edge of Write               | 0   |     | 0   |     | 0   |     | 0   |     | 0          | ns   |
| T12    | RD, E, PSEN, or DS<br>Pulse Width                                 | 40  |     | 45  |     | 60  |     | 75  |     | 0          | ns   |
| T12A   | WR Pulse Width                                                    | 20  |     | 25  |     | 35  |     | 45  |     | 0          | ns   |
| T13    | Trailing Edge of Write or<br>Read to Leading Edge<br>of ALE or AS | 0   |     | 0   |     | 0   |     | 0   |     | 0          | ns   |
| T14    | Address Valid to Trailing<br>Edge of Write                        | 90  |     | 120 |     | 150 |     | 200 |     | 0          | ns   |
| T15    | CSI Active to Trailing Edge<br>of Write                           | 100 |     | 130 |     | 160 |     | 200 |     | 0          | ns   |
| T16    | Write Data Set-up Time                                            | 20  |     | 25  |     | 30  |     | 40  |     | 0          | ns   |
| T17    | Write Data Hold Time                                              | 5   |     | 5   |     | 10  |     | 15  |     | 0          | ns   |
| T18    | Port to Data Out Valid<br>Propagation Delay                       |     | 30  |     | 30  |     | 35  |     | 45  | 0          | ns   |
| T19    | Port Input Hold Time                                              | 0   |     | 0   |     | 0   |     | 0   |     | 0          | ns   |
| T20    | Trailing Edge of Write<br>to Port Output Valid                    | 40  |     | 40  |     | 50  |     | 60  |     | 0          | ns   |
| T21    | ADi or Control to CSOi<br>Valid                                   | 6   | 25  | 6   | 30  | 6   | 35  | 5   | 45  | 0          | ns   |
| T22    | ADi or Control to CSOi<br>Invalid                                 | 5   | 25  | 5   | 30  | 4   | 35  | 4   | 45  | 0          | ns   |

#### **PSD302**

|        |                                                                                       | -5  | 00  | -1  | 2   | -15 |     | -20 |     | CMiser = 1 |      |
|--------|---------------------------------------------------------------------------------------|-----|-----|-----|-----|-----|-----|-----|-----|------------|------|
| Symbol | Parameter                                                                             | Min | Max | Min | Max | Min | Max | Min | Max | Add:*      | Unit |
| T23    | Track Mode Address<br>Propagation Delay:<br>CSADOUT1 Already True                     |     | 22  |     | 22  |     | 28  |     | 28  | 0          | ns   |
| T23A   | Track Mode Address<br>Propagation Delay:<br>CSADOUT1 Becomes<br>True During ALE or AS |     | 33  |     | 33  |     | 50  |     | 50  | 0          | ns   |
| T24    | Track Mode Trailing Edge<br>of ALE or AS to Address<br>High-Z                         |     | 32  |     | 32  |     | 35  |     | 40  | 0          | ns   |
| T25    | Track Mode Read<br>Propagation Delay                                                  |     | 29  |     | 29  |     | 35  |     | 35  | 0          | ns   |
| T26    | Track Mode Read<br>Hold Time                                                          | 11  | 29  | 11  | 29  | 10  | 29  | 10  | 35  | 0          | ns   |
| T27    | Track Mode Write Cycle,<br>Data Propagation Delay                                     |     | 20  |     | 20  |     | 30  |     | 30  | 0          | ns   |
| T28    | Track Mode Write<br>Cycle, Write to Data<br>Propagation Delay                         | 8   | 30  | 8   | 30  | 7   | 40  | 7   | 55  | 0          | ns   |
| T29    | Hold Time of Port A<br>Valid During Write<br>CSOi Trailing Edge                       | 2   |     | 2   |     | 2   |     | 2   |     | 0          | ns   |
| T30    | CSI Active to CSOi Active                                                             | 9   | 40  | 9   | 45  | 9   | 50  | 8   | 60  | 0          | ns   |
| T31    | CSI Inactive to CSOi<br>Inactive                                                      | 9   | 40  | 9   | 45  | 9   | 50  | 8   | 60  | 0          | ns   |
| T32    | Direct PAD Input as<br>Hold Time                                                      | 10  |     | 10  |     | 12  |     | 15  | -   | 0          | ns   |
| T33    | $R/\overline{W}$ Active to E or $\overline{DS}$ Start                                 | 20  |     | 20  |     | 30  |     | 40  |     | 0          | ns   |
| T34    | E or $\overline{\text{DS}}$ End to R/W                                                | 20  |     | 20  |     | 30  |     | 40  |     | 0          | ns   |
| T35    | AS Inactive to E high                                                                 | 0   |     | 0   |     | 0   |     | 0   |     | 0          | ns   |
| Т36    | Address to Leading<br>Edge of Write                                                   | 20  |     | 20  |     | 25  |     | 30  |     | 0          | ns   |

11. Control signals RD/E/DS or WR or R/W.

NOTES: 8. ADi = any address line. 9. CSOi = any of the chip-select output signals coming through Port B (CS0–CS7) or through Port C (CS8–CS10).

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

## **PSD302**



# **PSD302**



# **PSD302**



## **PSD302**



# **PSD302**



#### **Philips Semiconductors Microcontroller Peripherals**

# Field-programmable microcontroller peripheral

# **PSD302**



## **PSD302**



#### Philips Semiconductors Microcontroller Peripherals

# Field-programmable microcontroller peripheral

# **PSD302**



# **PSD302**

#### Figure 9. Chip-Select Output Timing



#### Philips Semiconductors Microcontroller Peripherals

## Field-programmable microcontroller peripheral

# **PSD302**



#### **PSD302**



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

Notes for Timing Diagrams

- 12. Direct PAD input = any of the following direct PAD input lines: CSI/A19 as transparent A19, RD/E, WR or R/W, transparent PC0–PC2, ALE in non-multiplexed modes.
- 13. Multiplexed inputs: any of the following inputs that are latched by the ALE (or AS): A0/AD0–A15/AD15, CSI/A19 as ALE dependent A19, ALE dependent PC0–PC2.
- CSOi = any of the chip-select output signals coming through Port B (CS0–CS7) or through Port C (CS8–CS10).
- 15. CSADOUT1, which internally enables the address transfer to Port A, should be derived only from direct PAD input signals, otherwise the address propagation delay is slowed down.
- 16. CSADIN and CSADOUT2, which internally enable the data-in or data-out transfers, respectively, can be derived from any combination of direct PAD inputs and multiplexed PAD inputs.
- 17. The write operation signals are included in the CSOi expression.
- Multiplexed PAD inputs: any of the following PAD inputs that are latched by the ALE (or AS) in the multiplexed modes: A11/AD11-A15/AD15, CSI/A19 as ALE dependent A19, ALE dependent PC0-PC2.
- 19. CSOi product terms can include any of the PAD input signals except for reset and CSI.

# Field-programmable microcontroller peripheral

### **PSD302**

| Pin<br>Capacitance <sup>20</sup> | Symbol | Parameter                           | Conditions             | Typical <sup>21</sup> | Max | Unit |
|----------------------------------|--------|-------------------------------------|------------------------|-----------------------|-----|------|
| Japaonanoe                       | CiN    | Capacitance (for input pins only)   | V <sub>IN</sub> = 0 V  | 4                     | 6   | рF   |
|                                  | COUT   | Capacitance (for input/output pins) | V <sub>OUT</sub> = 0 V | 8                     | 12  | рF   |
|                                  | CVPP   | Capacitance (for WR/VPP or R/W/VPP) | $V_{PP} = 0 V$         | 18                    | 25  | pF   |

NOTES: 20. This paramter is only sampled and is not 100% tested.

Typical values are for T<sub>A</sub> = 25°C and nominal supply voltages.



**PSD302** 

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

NOTE: 36. Pins 1, 13, 14, 26, 27, 39, 40, and 52 are No Connect.



**PSD302** 

# Field-programmable microcontroller peripheral

#### Figure 16. Drawing Q2 -] 48 RESET ] 47 <u>WR</u>V<sub>PP</sub> or RW ] 46 BHE/PSEN 52 Pin PQFP (Package Type Q) | 45 V<sub>cC</sub> | 44 A19/CSI 1 22 NC 51 PBS 1 28 PBS 1 49 PBS 1 49 PBS |43 PC2 |42 PC1 ]41 PC0 ]40 NC П 0 39 NC NC - 1 E 38 AD15/A15 PB4 2 [ PB3 37 AD14/A14 3 36 AD13/A13 PB2 4 PB1 5 35 AD12/A12 34 AD11/A11 PB0 6 33 GND GND 7 32 AD10/A10 ALE or AS 8 31 AD9/A9 PA7 9 30 AD8/A8 PA6 10 3 29 AD7/A7 PA5 11 PA4 12 28 AD6/A6 27 NC NC 13 NC 14 [ PA3 15 [ PA2 16 [ PA1 17 [ PA0 18 [ PA0 18 [ PA0 18 [ AD0/A0 20 [ AD1/A1 21 [ AD2/A2 22 [ AD3/A3 23 [ AD3/A3 24 [ AD5/A5 25 ] AD5/A5 25 [ AD5/A5 25 ] (TOP VIEW)

| Ordering<br>Information | Part Number   | Spd.<br>(ns) | Package<br>Type | Package<br>Drawing | Operating<br>Temperature<br>Range | WSI<br>Manufacturing<br>Procedure |
|-------------------------|---------------|--------------|-----------------|--------------------|-----------------------------------|-----------------------------------|
|                         | PSD302-90 A   | 90           | 44-pin PLCC     | J2                 | Commercial                        | Standard                          |
|                         | PSD302-90 KA  | 90           | 44-pin CLCC     | L4                 | Commercial                        | Standard                          |
|                         | PSD302-12 A   | 120          | 44-pin PLCC     | J2                 | Commercial                        | Standard                          |
|                         | PSD302-12 KA  | 120          | 44-pin CLCC     | L4                 | Commercial                        | Standard                          |
|                         | PSD302-12 B   | 120          | 52-pin PQFP     | Q2                 | Commercial                        | Standard                          |
|                         | PSD302-15 A   | 150          | 44-pin PLCC     | J2                 | Commercial                        | Standard                          |
|                         | PSD302-15I A  | 150          | 44-pin PLCC     | J2                 | Industrial                        | Standard                          |
|                         | PSD302-15 KA  | 150          | 44-pin CLCC     | L4                 | Commercial                        | Standard                          |
|                         | PSD302-15I KA | 150          | 44-pin CLCC     | L4                 | Industrial                        | Standard                          |
|                         | PSD302-15 B   | 150          | 52-pin PQFP     | Q2                 | Commercial                        | Standard                          |
|                         | PSD302-15I B  | 150          | 52-pin PQFP     | Q2                 | Industrial                        | Standard                          |
|                         | PSD302-20 A   | 200          | 44-pin PLCC     | J2                 | Commercial                        | Standard                          |
|                         | PSD302-20I A  | 200          | 44-pin PLCC     | J2                 | Industrial                        | Standard                          |
|                         | PSD302-20 KA  | 200          | 44-pin CLCC     | L4                 | Commercial                        | Standard                          |
|                         | PSD302-20I KA | 200          | 44-pin CLCC     | L4                 | Industrial                        | Standard                          |
|                         | PSD302-20 B   | 200          | 52-pin PQFP     | Q2                 | Commercial                        | Standard                          |
|                         | PSD302-201 B  | 200          | 52-pin PQFP     | Q2                 | Industrial                        | Standard                          |

#### Key Features

- Single Chip Programmable Peripheral for Microcontroller-based Applications
- 19 Individually Configurable I/O pins that can be used as:
- Microcontroller I/O port expansion
- Programmable Address Decoder (PAD) I/O
- Latched address output
- Open drain or CMOS
- Two Programmable Arrays (PAD A & PAD B)
- Total of 40 Product Terms and up to 16 Inputs and 24 Outputs
- Direct Address Decoding up to 1 Meg address space and up to 16 Meg with paging
- Logic replacement
- "No Glue" Microcontroller Chip-Set
- Built-in address latches for multiplexed address/data bus
- Non-multiplexed address/data bus mode
- 8-bit data bus width
- ALE and Reset polarity programmable
- Selectable modes for read and write control bus as RD/WR, R/W/E, or R/W/DS
- PSEN pin for 8051 users
- Built-In Page Logic
- To Expand the Address Space of Microcontrollers with Limited Address Space Capabilities
- Up to 16 pages

- 512 Kbits of UV EPROM
- Configurable as 64K x 8
- Divides into 8 equal mappable blocks for optimized mapping
- Block resolution is 8K x 8
- 120 ns EPROM access time, including input latches and PAD address decoding.
- 16 Kbit Static RAM
- Configurable as 2K x 8
- 120 ns SRAM access time, including input latches and PAD address decoding
- Address/Data Track Mode
- Enables easy Interface to Shared Resources (e.g., Mail Box SRAM) with other Microcontrollers or a Host Processor
- CMiser-Bit
- Programmable option to further reduce power consumption
- Built-In Security
- Locks the PSD312 and PAD Decoding Configuration
- Available in a Choice of Packages
- 44 Pin PLCC and CLCC
- 52 Pin PQFP
- □ Simple Menu-Driven Software: Configure the PSD312 on an IBM PC
- Pin and Function Compatible with the PSD31X

#### **PSD312**

| Security<br>Mode | Security Mode in the PSD3XX locks the<br>contents of the PAD A, PAD B and all the<br>configuration bits. The EPROM, SRAM,<br>and I/O contents can be accessed only<br>through the PAD. The Security Mode can<br>be set by the MAPLE or Programming          | software. In window packages, the mode is<br>erasable through UV full part erasure. In<br>the security mode, the PSD3XX contents<br>cannot be copied on a programmer.                                                                                                                                                                           |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CMiser-Bit       | The CMiser-Bit provides a programmable<br>option for power-sensitive applications that<br>require further reduction in power<br>consumption. The CMiser-Bit (CMiser = 1)<br>in the Maple portion of the PSD3XX sytem<br>development software can be used to | In the default mode, or if the PSD3XX is<br>configured without programming the<br>CMiser-Bit (CMiser = 0), the device<br>operates at specified speed and power<br>rating as specified in the A.C. and D.C.<br>Characteristics.                                                                                                                  |
|                  | reduce power consumption. The CMiser-Bit<br>turns off the EPROM blocks in the PSD3XX<br>whenever the EPROM is not accessed,<br>thereby reducing the active current.<br>consumed by the PSD3XX.                                                              | However, if the CMiser-Bit is programmed<br>(CMiser = 1), the device consumes even<br>lower current, and is reflected in the data<br>sheet. This mode has an adder in<br>propagation delay in T5, T6, and T7<br>parameters in the A.C. Characteristics, and<br>should be added to compute worst-case<br>timing requirements in the application. |

#### Absolute Maximum Ratings<sup>1</sup>

| Symbol           | Parameter                     | Condition           | Min   | Max   | Unit |
|------------------|-------------------------------|---------------------|-------|-------|------|
|                  | Starage Temperature           | CERDIP              | - 65  | + 150 | °C   |
| T <sub>STG</sub> | Storage Temperature           | PLASTIC             | - 65  | + 125 | °C   |
|                  | Voltage on any Pin            | With Respect to GND | - 0.6 | + 7   | v    |
| V <sub>PP</sub>  | Programming<br>Supply Voltage | With Respect to GND | - 0.6 | + 14  | v    |
| V <sub>cc</sub>  | Supply Voltage                | With Respect to GND | - 0.6 | + 7   | V    |
|                  | ESD Protection                |                     |       | >2000 | V    |

NOTE: 1. 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 theses or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to Absolute Maximum Rating conditions for extended periods of time may affect device reliability.

| Operating<br>Range | Range      | Temperature      | V <sub>CC</sub> | V <sub>CC</sub> Tolerance |       |      |  |  |
|--------------------|------------|------------------|-----------------|---------------------------|-------|------|--|--|
|                    |            |                  | - 66            | -12                       | -15   | -20  |  |  |
|                    | Commercial | 0° C to +70°C    | + 5 V           | ± 10%                     | ± 10% | ±10% |  |  |
|                    | Industrial | -40° C to +80°C  | + 5 V           |                           | ± 10% | ±10% |  |  |
|                    | Military   | -55° C to +125°C | + 5 V           |                           |       | ±10% |  |  |

| Recommended<br>Operating | Symbol          | Parameter                | Conditions                                         | Min | Тур | Max | Unit |
|--------------------------|-----------------|--------------------------|----------------------------------------------------|-----|-----|-----|------|
| Conditions               | V <sub>cc</sub> | Supply Voltage           | All Speeds                                         | 4.5 | 5   | 5.5 | V    |
| <i>vonunnene</i>         | VIH             | High-level Input Voltage | $V_{CC} = 4.5 \text{ V} \text{ to } 5.5 \text{ V}$ | 2   |     |     | V    |
|                          | V <sub>IL</sub> | Low-level Input Voltage  | $V_{CC} = 4.5 \text{ V to } 5.5 \text{ V}$         | 0   |     | 0.8 | V    |

DC

**Characteristics** 

# Field-programmable microcontroller peripheral

**PSD312** 

| Symbol           | Parameter                                 | Conditions                                          |     |      |      |     | Miser<br>Ibtrac | -   |     |
|------------------|-------------------------------------------|-----------------------------------------------------|-----|------|------|-----|-----------------|-----|-----|
| -                |                                           |                                                     | Min | Тур  | Мах  | Min | Тур             | Max | Uni |
| V <sub>OL</sub>  | Output Low                                | l <sub>OL</sub> = 20 μA<br>V <sub>CC</sub> = 4.5 V  |     | 0.01 | 0.1  |     |                 |     | v   |
| VOL              | Voltage                                   | l <sub>OL</sub> = 8 mA<br>V <sub>CC</sub> = 4.5 V   |     | 0.15 | 0.45 |     |                 |     | v   |
| V <sub>OH</sub>  | Output High                               | I <sub>OH</sub> = –20 μA<br>V <sub>CC</sub> = 4.5 V | 4.4 | 4.49 |      |     |                 |     | v   |
| чоп              | Voltage                                   | l <sub>OH</sub> = -2 mA<br>V <sub>CC</sub> = 4.5 V  | 2.4 | 3.9  |      |     |                 |     | v   |
| lan.             | V <sub>CC</sub> Standby<br>Current (CMOS) | Comm'l                                              |     | 50   | 100  |     |                 |     | μA  |
| I <sub>SB1</sub> | (Notes 2 and 4)                           | Ind/Mil                                             |     | 75   | 150  |     |                 |     | μA  |
| Block Selected)  |                                           | Comm'l<br>(Note 6)                                  |     | 16   | 35   |     | 7               | 10  | mA  |
|                  | (CMOS) (No<br>Internal Memory             | Comm'l<br>(Note 7)                                  |     | 28   | 50   |     | 7               | 10  | mA  |
|                  |                                           | Ind/Mil<br>(Note 6)                                 |     | 16   | 45   |     | 7               | 10  | mA  |
|                  |                                           | Ind/Mil<br>(Note 7)                                 |     | 28   | 60   |     | 7               | 10  | mA  |
|                  |                                           | Comm'l<br>(Note 6)                                  |     | 16   | 35   |     | 0               | 0   | mA  |
| I <sub>CC2</sub> | Active Current<br>(CMOS) (EPROM           | Comm'l<br>(Note 7)                                  |     | 28   | 50   |     | 0               | 0   | mA  |
| 1002             | Block Selected)<br>(Notes 2 and 5)        | Ind/Mil<br>(Note 6)                                 |     | 16   | 45   |     | 0               | 0   | mA  |
|                  |                                           | Ind/Mil<br>(Note 7)                                 |     | 28   | 60   |     | 0               | 0   | mA  |
|                  |                                           | Comm'l<br>(Note 6)                                  |     | 47   | 80   |     | 7               | 10  | mA  |
| lass             | Active Current<br>(CMOS) (SRAM            | Comm'l<br>(Note 7)                                  |     | 59   | 95   |     | 7               | 10  | mA  |
| I <sub>CC3</sub> | Block Selected<br>(Notes 2 and 5)         | Ind/Mil<br>(Note 6)                                 |     | 47   | 100  |     | 7               | 10  | mA  |
|                  |                                           | Ind/Mil<br>(Note 7)                                 |     | 59   | 115  |     | 7               | 10  | mA  |
| l <sub>LI</sub>  | Input Leakage<br>Current                  | V <sub>IN</sub> = 5.5 V<br>or GND                   | -1  | ±0.1 | 1    |     |                 |     | μA  |
| ILO              | Output Leakage<br>Current                 | V <sub>OUT</sub> = 5.5 V<br>or GND                  | -10 | ±5   | 10   |     |                 |     | μA  |

**NOTES:** 2. CMOS inputs: GND  $\pm$  0.3 V or V<sub>CC</sub>  $\pm$  0.3V. 3. <u>TTL</u> inputs: V<sub>IL</sub>  $\leq$  0.8 V, V<sub>IH</sub>  $\geq$  2.0 V. 4. <u>CSI/A19</u> is high and the part is in a power-down configuration mode. 5. Add 3.0 mA/MHz for AC power component (power = AC + DC).

6. Ten (10) PAD product terms active. (Add 380 μA per product term, typical, or 480 μA per product term maximum

7. Forty-one (41) PAD product terms active.

| AC Char | acteristics                                                       |     |     |     |     |     |     |     |     |            |      |
|---------|-------------------------------------------------------------------|-----|-----|-----|-----|-----|-----|-----|-----|------------|------|
|         |                                                                   | -9  | 0   | -1  | 2   | -1  | 5   | -2  | 20  | CMiser = 1 |      |
| Symbol  | Parameter                                                         | Min | Max | Min | Max | Min | Max | Min | Max | Add:       | Unit |
| T1      | ALE or AS Pulse Width                                             | 20  |     | 30  |     | 40  |     | 50  |     | 0          | ns   |
| T2      | Address Set-up Time                                               | 5   |     | 9   |     | 12  |     | 15  |     | 0          | ns   |
| Т3      | Address Hold Time                                                 | 8   |     | 9   |     | 12  |     | 15  |     | 0          | ns   |
| T4      | Leading Edge of Read to Data Active                               | 0   |     | 0   |     | 0   |     | 0   |     | 0          | ns   |
| T5      | ALE Valid to Data Valid                                           |     | 100 |     | 130 |     | 160 |     | 200 | 10         | ns   |
| T6      | Address Valid to Data Valid                                       |     | 90  |     | 120 |     | 150 |     | 200 | 10         | ns   |
| Т7      | CSI Active to Data Valid                                          |     | 100 |     | 130 |     | 160 |     | 200 | 15         | ns   |
| Т8      | Leading Edge of Read to Data Valid                                |     | 32  |     | 38  |     | 55  |     | 60  | 0          | ns   |
| Т9      | Read Data Hold Time                                               | 0   |     | 0   |     | 0   |     | 0   |     | 0          | ns   |
| T10     | Trailing Edge of Read to<br>Data High-Z                           |     | 32  |     | 32  |     | 35  |     | 40  | 0          | ns   |
| T11     | Trailing Edge of ALE or AS to Leading Edge of Write               | 0   |     | 0   |     | 0   |     | 0   |     | 0          | ns   |
| T12     | RD, E, PSEN, or DS<br>Pulse Width                                 | 40  |     | 45  |     | 60  |     | 75  |     | 0          | ns   |
| T12A    | WR Pulse Width                                                    | 20  |     | 25  |     | 35  |     | 45  |     | 0          | ns   |
| T13     | Trailing Edge of Write or<br>Read to Leading Edge<br>of ALE or AS | 0   |     | 0   |     | 0   |     | 0   |     | 0          | ns   |
| T14     | Address Valid to Trailing<br>Edge of Write                        | 90  |     | 120 |     | 150 |     | 200 |     | 0          | ns   |
| T15     | CSI Active to Trailing Edge<br>of Write                           | 100 |     | 130 |     | 160 |     | 200 |     | 0          | ns   |
| T16     | Write Data Set-up Time                                            | 20  |     | 25  |     | 30  |     | 40  |     | 0          | ns   |
| T17     | Write Data Hold Time                                              | 5   |     | 5   |     | 10  |     | 15  |     | 0          | ns   |
| T18     | Port to Data Out Valid<br>Propagation Delay                       |     | 30  |     | 30  |     | 35  |     | 45  | 0          | ns   |
| T19     | Port Input Hold Time                                              | 0   |     | 0   |     | 0   |     | 0   |     | 0          | ns   |
| T20     | Trailing Edge of Write to Port Output Valid                       | 40  |     | 40  |     | 50  |     | 60  |     | 0          | ns   |
| T21     | ADi or Control to CSOi<br>Valid                                   | 6   | 25  | 6   | 30  | 6   | 35  | 5   | 45  | 0          | ns   |
| T22     | ADi or Control to CSOi<br>Invalid                                 | 5   | 25  | 5   | 30  | 4   | 35  | 4   | 45  | 0          | ns   |

## **PSD312**

#### AC Characteristics (Cont.)

|        |                                                                                       | -9  | 0   | -1  | 2   | -1  | 5   | -20 |      | CMiser = 1 |      |
|--------|---------------------------------------------------------------------------------------|-----|-----|-----|-----|-----|-----|-----|------|------------|------|
| Symbol | Parameter                                                                             | Min | Max | Min | Max | Min | Max | Min | Max  | Add:       | Unit |
| T23    | Track Mode Address<br>Propagation Delay:<br>CSADOUT1 Already True                     |     | 22  |     | 22  |     | 28  |     | 28   | 0          | ns   |
| T23A   | Track Mode Address<br>Propagation Delay:<br>CSADOUT1 Becomes<br>True During ALE or AS |     | 33  |     | 33  |     | 50  |     | 50   | 0          | ns   |
| T24    | Track Mode Trailing Edge<br>of ALE or AS to Address<br>High-Z                         |     | 32  |     | 32  |     | 35  |     | 40 - | 0          | ns   |
| T25    | Track Mode Read<br>Propagation Delay                                                  |     | 29  |     | 29  |     | 35  |     | 35   | 0          | ns   |
| T26    | Track Mode Read<br>Hold Time                                                          | 11  | 29  | 11  | 29  | 10  | 29  | 10  | 35   | 0          | ns   |
| T27    | Track Mode Write Cycle,<br>Data Propagation Delay                                     |     | 20  |     | 20  |     | 30  |     | 30   | 0          | ns   |
| T28    | Track Mode Write<br>Cycle, Write to Data<br>Propagation Delay                         | 8   | 30  | 8   | 30  | 7   | 40  | 7   | 55   | 0          | ns   |
| T29    | Hold Time of Port A<br>Valid During Write<br>CSOi Trailing Edge                       | 2   |     | 2   |     | 2   |     | 2   |      | 0          | ns   |
| T30    | CSI Active to CSOi Active                                                             | 9   | 40  | 9   | 45  | 9   | 50  | 8   | 60   | 0          | ns   |
| T31    | CSI Inactive to CSOi<br>Inactive                                                      | 9   | 40  | 9   | 45  | 9   | 50  | 8   | 60   | 0          | ns   |
| T32    | Direct PAD Input as<br>Hold Time                                                      | 10  |     | 10  |     | 12  |     | 15  |      | 0          | ns   |
| T33    | $R/\overline{W}$ Active to E or $\overline{DS}$ Start                                 | 20  |     | 20  |     | 30  |     | 40  |      | 0          | ns   |
| T34    | E or $\overline{\text{DS}}$ End to R/ $\overline{\text{W}}$                           | 20  |     | 20  |     | 30  |     | 40  |      | 0          | ns   |
| T35    | AS Inactive to E high                                                                 | 0   |     | 0   |     | 0   |     | 0   |      | 0          | ns   |
| Т36    | Address to Leading<br>Edge of Write                                                   | 20  |     | 20  |     | 25  |     | 30  |      | 0          | ns   |

NOTES: 8. ADi = any address line.

9. CSOi = any of the chip-select output signals coming through Port B (CSO-CS7) or through Port C (CS8-CS10).

Direct PAD input = any of the following direct PAD input lines: CSI/A19 as transparent A19, RD/E/DS, WR or R/W, transparent PCO–PC2, ALE (or AS).
 Control signals RD/E/DS or WR or R/W.

## **PSD312**



#### **PSD312**



## **PSD312**



### **PSD312**



## **PSD312**

#### Figure 5. Chip-Select Output Timing



#### Philips Semiconductors Microcontroller Peripherals

### Field-programmable microcontroller peripheral

### **PSD312**



**PSD312** 



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

Notes for Timing Diagrams

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

### Field-programmable microcontroller peripheral

#### **PSD312**

| Pin<br>Capacitance <sup>20</sup> | Symbol | Parameter                                                    | Conditions             | Typical <sup>21</sup> | Max | Unit |
|----------------------------------|--------|--------------------------------------------------------------|------------------------|-----------------------|-----|------|
| oupuonanoo                       | CIN    | Capacitance (for input pins only)                            | $V_{IN} = 0 V$         | 4                     | 6   | pF   |
|                                  | COUT   | Capacitance (for input/output pins)                          | V <sub>OUT</sub> = 0 V | 8                     | 12  | pF   |
|                                  | CVPP   | Capacitance (for WR/V <sub>PP</sub> or R/W/V <sub>PP</sub> ) | V <sub>PP</sub> = 0 V  | 18                    | 25  | pF   |

NOTES: 20. This paramter is only sampled and is not 100% tested.

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



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

The PSD3XX and similar devices will erase with light sources having wavelengths shorter than 4000 Å. Although the erasure times will be much longer than with UV

light and sunlight eventually erases the device. For maximum system reliability, these sources should be avoided. If used in such an environment, the package windows should be covered by an opaque substance.

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

**PSD312** 

| Pin<br>Assignments | Pin Name                  | 44-Pin<br>PLCC/CLCC<br>Package | 52-Pin<br>PQFP Package |
|--------------------|---------------------------|--------------------------------|------------------------|
|                    | PSEN                      | 1                              | 46                     |
|                    | WR/V <sub>PP</sub> or R/W | 2                              | 47                     |
|                    | RESET                     | 3                              | 48                     |
|                    | PB7                       | 4                              | 49                     |
|                    | PB6                       | 5                              | 50                     |
|                    | PB5                       | 6                              | 51                     |
|                    | PB4                       | 7                              | 2                      |
|                    | PB3                       | 8                              | 3                      |
|                    | PB2                       | 9                              | 4                      |
|                    | PB1                       | 10                             | 5                      |
|                    | PB0                       | 11                             | 6                      |
|                    | GND                       | 12                             | 7                      |
|                    | ALE or AS                 | 13                             | 8                      |
|                    | PA7                       | 14                             | 9                      |
|                    | PA6                       | 15                             | 10                     |
|                    | PA5                       | 16                             | 11                     |
|                    | PA4                       | 17                             | 12                     |
|                    | PA3                       | 18                             | 15                     |
|                    | PA2                       | 19                             | 16                     |
|                    | PA1                       | 20                             | 17                     |
|                    | PAO                       | 21                             | 18                     |
|                    | RD/E/DS                   | 22                             | 19                     |
|                    | AD0/A0                    | 23                             | 20                     |
|                    | AD1/A1                    | 24                             | 21                     |
|                    | AD2/A2                    | 25                             | 22                     |
|                    | AD3/A3                    | 26                             | 23                     |
|                    | AD4/A4                    | 27                             | 24                     |
|                    | AD5/A5                    | 28                             | 25                     |
|                    | AD6/A6                    | 29                             | 28                     |
|                    | AD7/A7                    | 30                             | 29                     |
|                    | A8                        | 31                             | 30                     |
|                    | A9                        | 32                             | 31                     |
|                    | A10                       | 33                             | 32                     |
|                    | GND                       | 34                             | 33                     |
|                    | A11                       | 35                             | 34                     |
|                    | A12                       | 36                             | 35                     |
|                    | A13                       | 37                             | 36                     |
|                    | A14                       | 38                             | 37                     |
|                    | A15                       | 39                             | 38                     |
|                    | PC0                       | 40                             | 41                     |
|                    | PC1                       | 40                             | 41                     |
|                    | PC2                       | 41                             | 42                     |
|                    | A19/CSI                   | 42                             | 43                     |
|                    | V <sub>cc</sub>           | 43                             | 44                     |
|                    | V °CC                     | 44                             | 40                     |

NOTE: 36. Pins 1, 13, 14, 26, 27, 39, 40, and 52 are No Connect.









| Ordering<br>Information | Part Number   | Spd.<br>(ns) | Package<br>Type | Package<br>Drawing | Operating<br>Temperature<br>Range | Manufacturing<br>Procedure |
|-------------------------|---------------|--------------|-----------------|--------------------|-----------------------------------|----------------------------|
|                         | PSD312-90 A   | 90           | 44-pin PLCC     | J2                 | Commercial                        | Standard                   |
|                         | PSD312-90 KA  | 90           | 44-pin CLCC     | L4                 | Commercial                        | Standard                   |
|                         | PSD312-12 A   | 120          | 44-pin PLCC     | J2                 | Commercial                        | Standard                   |
|                         | PSD312-12 KA  | 120          | 44-pin CLCC     | L4                 | Commercial                        | Standard                   |
|                         | PSD312-12 B   | 120          | 52-pin PQFP     | Q2                 | Commercial                        | Standard                   |
|                         | PSD312-15 A   | 150          | 44-pin PLCC     | J2                 | Commercial                        | Standard                   |
|                         | PSD312-15I A  | 150          | 44-pin PLCC     | J2                 | Industrial                        | Standard                   |
|                         | PSD312-15 KA  | 150          | 44-pin CLCC     | L4                 | Commercial                        | Standard                   |
|                         | PSD312-15I KA | 150          | 44-pin CLCC     | L4                 | Industrial                        | Standard                   |
|                         | PSD312-15 B   | 150          | 52-pin PQFP     | Q2                 | Commercial                        | Standard                   |
|                         | PSD312-15I B  | 150          | 52-pin PQFP     | Q2                 | Industrial                        | Standard                   |
|                         | PSD312-20 A   | 200          | 44-pin PLCC     | J2                 | Commercial                        | Standard                   |
|                         | PSD312-20I A  | 200          | 44-pin PLCC     | J2                 | Industrial                        | Standard                   |
|                         | PSD312-20 KA  | 200          | 44-pin CLCC     | L4                 | Commercial                        | Standard                   |
|                         | PSD312-20I KA | 200          | 44-pin CLCC     | L4                 | Industrial                        | Standard                   |
|                         | PSD312-20 B   | 200          | 52-pin PQFP     | Q2                 | Commercial                        | Standard                   |
|                         | PSD312-20I B  | 200          | 52-pin PQFP     | Q2                 | Industrial                        | Standard                   |

#### **Key Features**

- Single Chip Programmable Peripheral for Microcontroller-based Applications
- 19 Individually Configurable I/O pins that can be used as:
- Microcontroller I/O port expansion
- Programmable Address Decoder (PAD) I/O
- Latched address output
- Open drain or CMOS
- Two Programmable Arrays (PAD A & PAD B)
- Total of 40 Product Terms and up to 16 Inputs and 24 Outputs
- Direct Address Decoding up to 1 Meg address space and up to 16 Meg with paging
- Logic replacement
- "No Glue" Microcontroller Chip-Set
- Built-in address latches for multiplexed address/data bus
- Non-multiplexed address/data bus mode
- Selectable 8 or 16 bit data bus width
- ALE and Reset polarity programmable
- Selectable modes for read and write control bus as RD/WR, R/W/E, or R/W/DS
- BHE pin for byte select in 16-bit mode
- PSEN pin for 8051 users
- Built-In Page Logic
- To Expand the Address Space of Microcontrollers with Limited Address Space Capabilities
- Up to 16 pages

- 1 M bit of UV EPROM
- Configurable as 128K x 8 or as 64K x 16
- Divides into 8 equal mappable blocks for optimized mapping
- Block resolution is 16K x 8 or 8K x 16
- 120 ns EPROM access time, including input latches and PAD address decoding.
- 16 Kbit Static RAM
- Configurable as 2K x 8 or as 1K x 16
- 120 ns SRAM access time, including input latches and PAD address decoding
- Address/Data Track Mode
- Enables easy Interface to Shared Resources (e.g., Mail Box SRAM) with other Microcontrollers or a Host Processor
- Built-In Security
- Locks the PSD303 and PAD Decoding Configuration
- Available in a Choice of Packages
- 44 Pin PLCC and CLCC
- Simple Menu-Driven Software: Configure the PSD303 on an IBM PC
- Pin and Function Compatible with the PSD301 and PSD302

**PSD303** 

**Preliminary specification** 

#### **PSD303**

| Security<br>Mode | Security Mode in the PSD3XX locks the<br>contents of the PAD A, PAD B and all the<br>configuration bits. The EPROM, SRAM,<br>and I/O contents can be accessed only<br>through the PAD. The Security Mode can<br>be set by the MAPLE or Programming          | software. In window packages, the mode is<br>erasable through UV full part erasure. In<br>the security mode, the PSD3XX contents<br>cannot be copied on a programmer.                                                                                                                                |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CMiser-Bit       | The CMiser-Bit provides a programmable<br>option for power-sensitive applications that<br>require further reduction in power<br>consumption. The CMiser-Bit (CMiser = 1)<br>in the Maple portion of the PSD3XX sytem<br>development software can be used to | In the default mode, or if the PSD3XX is<br>configured without programming the<br>CMiser-Bit (CMiser = 0), the device<br>operates at specified speed and power<br>rating as specified in the A.C. and D.C.<br>Characteristics.                                                                       |
|                  | reduce power consumption. The CMiser-Bit<br>turns off the EPROM blocks in the PSD3XX<br>whenever the EPROM is not accessed,<br>thereby reducing the active current<br>consumed by the PSD3XX.                                                               | However, if the CMiser-Bit is programmed<br>(CMiser = 1), the device consumes even<br>lower current, and is reflected in the data<br>sheet. This mode has an adder in<br>propagation delay in T5, T6, and T7<br>parameters in the A.C. Characteristics, and<br>should be added to compute worst-case |

#### Absolute Maximum Ratings<sup>1</sup>

| Symbol           | Parameter                     | Condition           | Min   | Max   | Unit |
|------------------|-------------------------------|---------------------|-------|-------|------|
| +                |                               | CERDIP              | - 65  | + 150 | °C   |
| T <sub>STG</sub> | Storage Temperature           | PLASTIC             | - 65  | + 125 | °C   |
|                  | Voltage on any Pin            | With Respect to GND | - 0.6 | +7    | V    |
| V <sub>PP</sub>  | Programming<br>Supply Voltage | With Respect to GND | - 0.6 | + 14  | v    |
| V <sub>cc</sub>  | Supply Voltage                | With Respect to GND | - 0.6 | + 7   | V    |
|                  | ESD Protection                |                     |       | >2000 | ٧    |

timing requirements in the application.

NOTE: 1. 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 theses or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to Absolute Maximum Rating conditions for extended periods of time may affect device reliability.

| <i>Operating<br/>Range</i> | Range      | Temperature        | V <sub>CC</sub> | 5     | <sub>CC</sub> Tolerai | ice   |
|----------------------------|------------|--------------------|-----------------|-------|-----------------------|-------|
| nallyt                     | ,          | <i>Temperature</i> | - 66            | -12   | -15                   | -20   |
|                            | Commercial | 0° C to +70°C      | + 5 V           | ± 10% | ± 10%                 | ± 10% |
|                            | Industrial | -40° C to +80°C    | + 5 V           |       | ± 10%                 | ± 10% |
|                            | Military   | -55° C to +125°C   | + 5 V           |       |                       | ±10%  |

| Recommended<br>Operating | Symbol          | Parameter                | Conditions                                 | Min | Тур | Max | Unit |
|--------------------------|-----------------|--------------------------|--------------------------------------------|-----|-----|-----|------|
| Conditions               | V <sub>cc</sub> | Supply Voltage           | All Speeds                                 | 4.5 | 5   | 5.5 | V    |
|                          | VIH             | High-level Input Voltage | $V_{CC} = 4.5 \text{ V to } 5.5 \text{ V}$ | 2   |     |     | V    |
|                          | VIL             | Low-level Input Voltage  | $V_{CC} = 4.5 V \text{ to } 5.5 V$         | 0   |     | 0.8 | V    |

# Field-programmable microcontroller peripheral

**PSD303** 

| DC<br>Characteristics | Symbol           | Parameter                                       | Conditions                                          |     |      |      |     | Niser<br>Ibtrac |     |      |
|-----------------------|------------------|-------------------------------------------------|-----------------------------------------------------|-----|------|------|-----|-----------------|-----|------|
|                       |                  |                                                 |                                                     | Min | Тур  | Max  | Min | Тур             | Max | Unit |
|                       | V <sub>OL</sub>  | Output Low                                      | I <sub>OL</sub> = 20 μA<br>V <sub>CC</sub> = 4.5 V  |     | 0.01 | 0.1  |     |                 |     | v    |
|                       | •01              | Voltage                                         | l <sub>OL</sub> = 8 mA<br>V <sub>CC</sub> = 4.5 V   |     | 0.15 | 0.45 |     |                 |     | v    |
|                       | V <sub>OH</sub>  | Output High                                     | I <sub>OH</sub> = -20 μA<br>V <sub>CC</sub> = 4.5 V | 4.4 | 4.49 |      |     |                 |     | v    |
|                       | V OH             | Voltage                                         | l <sub>OH</sub> = -2 mA<br>V <sub>CC</sub> = 4.5 V  | 2.4 | 3.9  |      |     |                 |     | v    |
|                       | I <sub>SB1</sub> | V <sub>CC</sub> Standby<br>Current (CMOS)       | Comm'l                                              |     | 50   | 100  |     |                 |     | μA   |
|                       | 'SB1             | (Notes 2 and 4)                                 | Ind/Mil                                             |     | 75   | 150  |     |                 |     | μA   |
|                       |                  |                                                 | Comm'l<br>(Note 6)                                  |     | 16   | 35   |     | 7               | 10  | mA   |
|                       | I <sub>CC1</sub> | Active Current<br>(CMOS) (No<br>Internal Memory | Comm'l<br>(Note 7)                                  |     | 28   | 50   |     | 7               | 10  | mA   |
|                       |                  | Block Selected)<br>(Notes 2 and 5)              | Ind/Mil<br>(Note 6)                                 |     | 16   | 45   |     | 7               | 10  | mA   |
|                       |                  | (                                               | Ind/Mil<br>(Note 7)                                 |     | 28   | 60   |     | 7               | 10  | mA   |
|                       |                  |                                                 | Comm'l<br>(Note 6)                                  | l   | 16   | 35   |     | 0               | 0   | mA   |
|                       | Icc2             | Active Current<br>(CMOS) (EPROM                 | Comm'l<br>(Note 7)                                  |     | 28   | 50   |     | 0               | 0   | mA   |
|                       | 1002             | Block Selected)<br>(Notes 2 and 5)              | Ind/Mil<br>(Note 6)                                 |     | 16   | 45   |     | 0               | 0   | mA   |
|                       |                  |                                                 | Ind/Mil<br>(Note 7)                                 |     | 28   | 60   |     | 0               | 0   | mA   |
|                       |                  |                                                 | Comm'l<br>(Note 6)                                  |     | 47   | 80   |     | 7               | 10  | mA   |
|                       | I <sub>CC3</sub> | Active Current<br>(CMOS) (SRAM                  | Comm'l<br>(Note 7)                                  |     | 59   | 95   |     | 7               | 10  | mA   |
|                       | 1003             | Block Selected<br>(Notes 2 and 5)               | Ind/Mil<br>(Note 6)                                 |     | 47   | 100  |     | 7               | 10  | mA   |
|                       |                  |                                                 | Ind/Mil<br>(Note 7)                                 |     | 59   | 115  |     | 7               | 10  | mA   |
|                       | I <sub>LI</sub>  | Input Leakage<br>Current                        | V <sub>IN</sub> = 5.5 V<br>or GND                   | -1  | ±0.1 | 1    |     |                 |     | μA   |
|                       | ILO              | Output Leakage<br>Current                       | V <sub>OUT</sub> = 5.5 V<br>or GND                  | -10 | ±5   | 10   |     |                 |     | μA   |

**NOTES:** 2. CMOS inputs: GND  $\pm$  0.3 V or V<sub>CC</sub>  $\pm$  0.3V. 3. <u>TTL</u> inputs: V<sub>IL</sub>  $\leq$  0.8 V, V<sub>IH</sub>  $\geq$  2.0 V. 4. CSI/A19 is high and the part is in a power-down configuration mode. 5. Add 3.0 mA/MHz for AC power component (power = AC + DC). 6. Ten (10) PAD product terms active. (Add 380 µA per product term, typical, or 480 µA per product term maximum
 Forty-one (41) PAD product terms active.

| AC Char | acteristics                                                       |     |     |     |     |     |     |     |     |            |      |
|---------|-------------------------------------------------------------------|-----|-----|-----|-----|-----|-----|-----|-----|------------|------|
|         |                                                                   | -9  | 0   | -1  | 2   | -1  | 5   | -2  | 20  | CMiser = 1 |      |
| Symbol  | Parameter                                                         | Min | Max | Min | Max | Min | Max | Min | Max | Add:       | Unit |
| T1      | ALE or AS Pulse Width                                             | 20  |     | 30  |     | 40  |     | 50  |     | 0          | ns   |
| T2      | Address Set-up Time                                               | 5   |     | 9   |     | 12  |     | 15  |     | 0          | ns   |
| Т3      | Address Hold Time                                                 | 8   |     | 9   |     | 12  |     | 15  |     | 0          | ns   |
| T4      | Leading Edge of Read to Data Active                               | 0   |     | 0   |     | 0   |     | 0   |     | 0          | ns   |
| T5      | ALE Valid to Data Valid                                           |     | 100 |     | 130 |     | 160 |     | 200 | 10         | ns   |
| Т6      | Address Valid to Data Valid                                       |     | 90  |     | 120 |     | 150 |     | 200 | 10         | ns   |
| T7      | CSI Active to Data Valid                                          |     | 100 |     | 130 |     | 160 |     | 200 | 15         | ns   |
| Т8      | Leading Edge of Read to Data Valid                                |     | 32  |     | 38  |     | 55  |     | 60  | 0          | ns   |
| Т9      | Read Data Hold Time                                               | 0   |     | 0   |     | 0   |     | 0   |     | 0          | ns   |
| T10     | Trailing Edge of Read to<br>Data High-Z                           |     | 32  |     | 32  |     | 35  |     | 40  | 0          | ns   |
| T11     | Trailing Edge of ALE or AS to Leading Edge of Write               | 0   |     | 0   |     | 0   |     | 0   |     | 0          | ns   |
| T12     | RD, E, PSEN, or DS<br>Pulse Width                                 | 40  |     | 45  |     | 60  |     | 75  |     | 0          | ns   |
| T12A    | WR Pulse Width                                                    | 20  |     | 25  |     | 35  |     | 45  |     | 0          | ns   |
| T13     | Trailing Edge of Write or<br>Read to Leading Edge<br>of ALE or AS | 0   |     | 0   |     | 0   |     | 0   |     | 0          | ns   |
| T14     | Address Valid to Trailing<br>Edge of Write                        | 90  |     | 120 |     | 150 |     | 200 |     | 0          | ns   |
| T15     | CSI Active to Trailing Edge<br>of Write                           | 100 |     | 130 |     | 160 |     | 200 |     | 0          | ns   |
| T16     | Write Data Set-up Time                                            | 20  |     | 25  |     | 30  |     | 40  |     | 0          | ns   |
| T17     | Write Data Hold Time                                              | 5   |     | 5   |     | 10  |     | 15  |     | 0          | ns   |
| T18     | Port to Data Out Valid<br>Propagation Delay                       |     | 30  |     | 30  |     | 35  |     | 45  | 0          | ns   |
| T19     | Port Input Hold Time                                              | 0   |     | 0   |     | 0   |     | 0   |     | 0          | ns   |
| T20     | Trailing Edge of Write<br>to Port Output Valid                    | 40  |     | 40  |     | 50  |     | 60  |     | 0          | ns   |
| T21     | ADi or Control to CSOi<br>Valid                                   | 6   | 25  | 6   | 30  | 6   | 35  | 5   | 45  | 0          | ns   |
| T22     | ADi or Control to CSOi<br>Invalid                                 | 5   | 25  | 5   | 30  | 4   | 35  | 4   | 45  | 0          | ns   |

#### **PSD303**

#### AC Characteristics (Cont.)

|             |                                                                                       | -9  | 0   | -1  | 2   | -1  | 5   | -2  | 20  | CMiser = 1 |      |
|-------------|---------------------------------------------------------------------------------------|-----|-----|-----|-----|-----|-----|-----|-----|------------|------|
| Symbol      | Parameter                                                                             | Min | Max | Min | Max | Min | Max | Min | Max | Add:       | Unit |
| T23         | Track Mode Address<br>Propagation Delay:<br>CSADOUT1 Already True                     |     | 22  |     | 22  |     | 28  |     | 28  | 0          | ns   |
| T23A        | Track Mode Address<br>Propagation Delay:<br>CSADOUT1 Becomes<br>True During ALE or AS |     | 33  |     | 33  |     | 50  |     | 50  | 0          | ns   |
| T24         | Track Mode Trailing Edge<br>of ALE or AS to Address<br>High-Z                         |     | 32  |     | 32  |     | 35  |     | 40  | 0          | ns   |
| T25         | Track Mode Read<br>Propagation Delay                                                  |     | 29  |     | 29  |     | 35  |     | 35  | 0          | ns   |
| T26         | Track Mode Read<br>Hold Time                                                          | 11  | 29  | 11  | 29  | 10  | 29  | 10  | 35  | 0          | ns   |
| T27         | Track Mode Write Cycle,<br>Data Propagation Delay                                     |     | 20  |     | 20  |     | 30  |     | 30  | 0          | ns   |
| T28         | Track Mode Write<br>Cycle, Write to Data<br>Propagation Delay                         | 8   | 30  | 8   | 30  | 7   | 40  | 7   | 55  | 0          | ns   |
| T29         | Hold Time of Port A<br><u>Valid</u> During Write<br>CSOi Trailing Edge                | 2   |     | 2   |     | 2   |     | 2   |     | 0          | ns   |
| Т30         | CSI Active to CSOi Active                                                             | 9   | 40  | 9   | 45  | 9   | 50  | 8   | 60  | 0          | ns   |
| T31         | CSI Inactive to CSOi<br>Inactive                                                      | 9   | 40  | 9   | 45  | 9   | 50  | 8   | 60  | 0          | ns   |
| T32         | Direct PAD Input as<br>Hold Time                                                      | 10  |     | 10  |     | 12  |     | 15  |     | 0          | ns   |
| T33         | $R/\overline{W}$ Active to E or $\overline{DS}$ Start                                 | 20  |     | 20  |     | 30  |     | 40  |     | 0          | ns   |
| T34         | E or $\overline{\text{DS}}$ End to R/W                                                | 20  |     | 20  |     | 30  |     | 40  |     | 0          | ns   |
| T <b>35</b> | AS Inactive to E high                                                                 | 0   |     | 0   |     | 0   |     | 0   |     | 0          | ns   |
| Т36         | Address to Leading<br>Edge of Write                                                   | 20  |     | 20  |     | 25  |     | 30  |     | 0          | ns   |

**NOTES:** 8. <u>ADi =</u> any address line.

9. CSOi = any of the chip-select output signals coming through Port B (CS0-CS7) or through Port C (CS8-CS10).

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

11. Control signals RD/E/DS or WR or R/W.

#### **PSD303**



#### Philips Semiconductors Microcontroller Peripherals

## Field-programmable microcontroller peripheral

### **PSD303**



#### **PSD303**



#### **PSD303**



## **PSD303**



#### **PSD303**



### **PSD303**



## **PSD303**



#### **PSD303**

#### Figure 9. Chip-Select Output Timing



#### Philips Semiconductors Microcontroller Peripherals

# Field-programmable microcontroller peripheral

## **PSD303**



**PSD303** 

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



#### Notes for Timing Diagrams

- 12. Direct PAD input = any of the following direct PAD input lines: CSI/A19 as transparent A19, RD/E, WR or R/W, transparent PC0–PC2, ALE in non-multiplexed modes.
- Multiplexed inputs: any of the following inputs that are latched by the ALE (or AS): A0/AD0–A15/AD15, CSI/A19 as ALE dependent A19, ALE dependent PC0–PC2.
- 14. CSOi = any of the chip-select output signals coming through Port B (CS0–CS7) or through Port C (CS8–CS10).
- 15. CSADOUT1, which internally enables the address transfer to Port A, should be derived only from direct PAD input signals, otherwise the address propagation delay is slowed down.
- 16. CSADIN and CSADOUT2, which internally enable the data-in or data-out transfers, respectively, can be derived from any combination of direct PAD inputs and multiplexed PAD inputs.
- 17. The write operation signals are included in the CSOi expression.
- Multiplexed PAD inputs: any of the following PAD inputs that are latched by the ALE (or AS) in the multiplexed modes: A11/AD11-A15/AD15, CSI/A19 as ALE dependent A19, ALE dependent PC0-PC2.
- 19. CSOi product terms can include any of the PAD input signals except for reset and CSI.

## Field-programmable microcontroller peripheral

#### **PSD303**

| Pin<br>Capacitance <sup>20</sup> | Symbol          | Parameter                           | <b>Conditions</b>      | Typical <sup>21</sup> | Max | Unit |
|----------------------------------|-----------------|-------------------------------------|------------------------|-----------------------|-----|------|
| Japachanoc                       | C <sub>iN</sub> | Capacitance (for input pins only)   | V <sub>IN</sub> = 0 V  | 4                     | 6   | pF   |
|                                  | COUT            | Capacitance (for input/output pins) | V <sub>OUT</sub> = 0 V | 8                     | 12  | pF   |
|                                  | CVPP            | Capacitance (for WR/VPP or R/W/VPP) | V <sub>PP</sub> = 0 V  | 18                    | 25  | pF   |

NOTES: 20. This paramter is only sampled and is not 100% tested.

21. Typical values are for T<sub>A</sub> = 25°C and nominal supply voltages.



PAD MAP data are loaded through the

procedure of programming.

shorter than 4000 Å. Although the erasure

times will be much longer than with UV

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



| Ordering<br>Information | Part Number   | Spd.<br>(ns) | Package<br>Type | Package<br>Drawing | Operating<br>Temperature<br>Range | WSI<br>Manufacturing<br>Procedure |
|-------------------------|---------------|--------------|-----------------|--------------------|-----------------------------------|-----------------------------------|
|                         | PSD303-90 A   | 90           | 44-pin PLCC     | J2                 | Commercial                        | Standard                          |
|                         | PSD303-90 KA  | 90           | 44-pin CLCC     | L4                 | Commercial                        | Standard                          |
|                         | PSD303-12 A   | 120          | 44-pin PLCC     | J2                 | Commercial                        | Standard                          |
|                         | PSD303-12 KA  | 120          | 44-pin CLCC     | L4                 | Commercial                        | Standard                          |
|                         | PSD303-15 A   | 150          | 44-pin PLCC     | J2                 | Commercial                        | Standard                          |
|                         | PSD303-15I A  | 150          | 44-pin PLCC     | J2                 | Industrial                        | Standard                          |
|                         | PSD303-15KA   | 150          | 44-pin CLCC     | L4                 | Commercial                        | Standard                          |
|                         | PSD303-15I KA | 150          | 44-pin CLCC     | L4                 | Industrial                        | Standard                          |
|                         | PSD303-20 A   | 200          | 44-pin PLCC     | J2                 | Commercial                        | Standard                          |
|                         | PSD303-201 A  | 200          | 44-pin PLCC     | J2                 | Industrial                        | Standard                          |
|                         | PSD303-20 KA  | 200          | 44-pin CLCC     | L4                 | Commercial                        | Standard                          |
|                         | PSD303-20I KA | 200          | 44-pin CLCC     | L4                 | Industrial                        | Standard                          |

#### **Key Features**

- Single Chip Programmable Peripheral for Microcontroller-based Applications
- 19 Individually Configurable I/O pins that can be used as:
- Microcontroller I/O port expansion
- Programmable Address Decoder (PAD) I/O
- Latched address output
- Open drain or CMOS
- Two Programmable Arrays (PAD A & PAD B)
- --- Total of 40 Product Terms and up to 16 Inputs and 24 Outputs
- Direct Address Decoding up to 1 Meg address space and up to 16 Meg with paging
- Logic replacement
- "No Glue" Microcontroller Chip-Set
- Built-in address latches for multiplexed address/data bus
- Non-multiplexed address/data bus mode
- 8-bit data bus width
- ALE and Reset polarity programmable
- Selectable modes for read and write control bus as RD/WR, R/W/E, or R/W/DS
- PSEN pin for 8051 users
- Built-In Page Logic
- To Expand the Address Space of Microcontrollers with Limited Address Space Capabilities
- Up to 16 pages

- 1 M bit of UV EPROM
- Configurable as 128K x 8
- Divides into 8 equal mappable blocks for optimized mapping
- Block resolution is 16K x 8
- 120 ns EPROM access time, including input latches and PAD address decoding.
- 16 Kbit Static RAM
- Configurable as 2K x 8
- 120 ns SRAM access time, including input latches and PAD address decoding
- Address/Data Track Mode
- Enables easy Interface to Shared Resources (e.g., Mail Box SRAM) with other Microcontrollers or a Host Processor
- Built-In Security
- Locks the PSD313 and PAD Decoding Configuration
- Available in a Choice of Packages
- 44 Pin PLDCC and CLDCC
- □ Simple Menu-Driven Software: Configure the PSD313 on an IBM PC
- Pin Compatible with the PSD311 and PSD312

timing requirements in the application.

### Field-programmable microcontroller peripheral

#### **PSD313**

| Security<br>Mode | Security Mode in the PSD3XX locks the<br>contents of the PAD A, PAD B and all the<br>configuration bits. The EPROM, SRAM,<br>and I/O contents can be accessed only<br>through the PAD. The Security Mode can<br>be set by the MAPLE or Programming          | software. In window packages, the mode is<br>erasable through UV full part erasure. In<br>the security mode, the PSD3XX contents<br>cannot be copied on a programmer.                                                                                                                                |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CMiser-Bit       | The CMiser-Bit provides a programmable<br>option for power-sensitive applications that<br>require further reduction in power<br>consumption. The CMiser-Bit (CMiser = 1)<br>in the Maple portion of the PSD3XX sytem<br>development software can be used to | In the default mode, or if the PSD3XX is<br>configured without programming the<br>CMiser-Bit (CMiser = 0), the device<br>operates at specified speed and power<br>rating as specified in the A.C. and D.C.<br>Characteristics.                                                                       |
|                  | reduce power consumption. The CMiser-Bit<br>turns off the EPROM blocks in the PSD3XX<br>whenever the EPROM is not accessed,<br>thereby reducing the active current<br>consumed by the PSD3XX.                                                               | However, if the CMiser-Bit is programmed<br>(CMiser = 1), the device consumes even<br>lower current, and is reflected in the data<br>sheet. This mode has an adder in<br>propagation delay in T5, T6, and T7<br>parameters in the A.C. Characteristics, and<br>should be added to compute worst-case |

#### Absolute Maximum Ratings<sup>1</sup>

| Symbol              | Parameter                     | Condition           | Min   | Max   | Unit |
|---------------------|-------------------------------|---------------------|-------|-------|------|
| T <sub>STG</sub> \$ | Starage Temperature           | CERDIP              | - 65  | + 150 | °C   |
|                     | Storage Temperature           | PLASTIC             | - 65  | + 125 | °C   |
|                     | Voltage on any Pin            | With Respect to GND | - 0.6 | +7    | ٧    |
| V <sub>PP</sub>     | Programming<br>Supply Voltage | With Respect to GND | - 0.6 | + 14  | v    |
| V <sub>cc</sub>     | Supply Voltage                | With Respect to GND | - 0.6 | + 7   | ٧    |
|                     | ESD Protection                |                     |       | >2000 | V    |

NOTE: 1. 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 theses or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to Absolute Maximum Rating conditions for extended periods of time may affect device reliability.

| <i>Operating<br/>Range</i> | Range      | Temperature      | V <sub>CC</sub> | V <sub>CC</sub> Tolerance |       |       |  |
|----------------------------|------------|------------------|-----------------|---------------------------|-------|-------|--|
|                            | nango      |                  |                 | -12                       | -15   | -20   |  |
|                            | Commercial | 0° C to +70°C    | + 5 V           | ± 10%                     | ± 10% | ± 10% |  |
|                            | Industrial | -40° C to +80°C  | + 5 V           |                           | ± 10% | ± 10% |  |
|                            | Military   | -55° C to +125°C | + 5 V           |                           |       | ± 10% |  |

| Recommended<br>Operating | Symbol          | Parameter                | Conditions                                 | Min | Тур | Max | Unit |
|--------------------------|-----------------|--------------------------|--------------------------------------------|-----|-----|-----|------|
| Conditions               | V <sub>cc</sub> | Supply Voltage           | All Speeds                                 | 4.5 | 5   | 5.5 | V    |
| 00                       | VIH             | High-level Input Voltage | $V_{CC} = 4.5 V \text{ to } 5.5 V$         | 2   |     |     | V    |
|                          | VIL             | Low-level Input Voltage  | $V_{CC} = 4.5 \text{ V to } 5.5 \text{ V}$ | 0   |     | 0.8 | V    |

## Field-programmable microcontroller peripheral

**PSD313** 

| DC<br>Characteristics | Symbol           | Parameter                                                                             | Conditions                                          |     |      |      | CMiser = 1<br>Subtract: |     |     |      |
|-----------------------|------------------|---------------------------------------------------------------------------------------|-----------------------------------------------------|-----|------|------|-------------------------|-----|-----|------|
|                       |                  |                                                                                       |                                                     | Min | Тур  | Max  | Min                     | Тур | Max | Unit |
|                       | V <sub>OL</sub>  | Output Low<br>Voltage                                                                 | I <sub>OL</sub> = 20 μA<br>V <sub>CC</sub> = 4.5 V  |     | 0.01 | 0.1  |                         |     |     | v    |
|                       | - OL             |                                                                                       | I <sub>OL</sub> = 8 mA<br>V <sub>CC</sub> = 4.5 V   |     | 0.15 | 0.45 |                         |     |     | v    |
|                       | V <sub>OH</sub>  | Output High                                                                           | I <sub>OH</sub> = -20 μA<br>V <sub>CC</sub> = 4.5 V | 4.4 | 4.49 |      |                         |     |     | v    |
|                       | - On             | Voltage                                                                               | l <sub>OH</sub> = -2 mA<br>V <sub>CC</sub> = 4.5 V  | 2.4 | 3.9  |      |                         |     |     | v    |
|                       | I <sub>SB1</sub> | V <sub>CC</sub> Standby<br>Current (CMOS)<br>(Notes 2 and 4)                          | Comm'l                                              |     | 50   | 100  |                         |     |     | μA   |
|                       | 1381             |                                                                                       | Ind/Mil                                             |     | 75   | 150  |                         |     |     | μA   |
|                       |                  | Active Current<br>(CMOS) (No<br>Internal Memory<br>Block Selected)<br>(Notes 2 and 5) | Comm'l<br>(Note 6)                                  |     | 16   | 35   |                         | 7   | 10  | mA   |
|                       | Icc1             |                                                                                       | Comm'l<br>(Note 7)                                  |     | 28   | 50   |                         | 7   | 10  | mA   |
|                       |                  |                                                                                       | Ind/Mil<br>(Note 6)                                 |     | 16   | 45   |                         | 7   | 10  | mA   |
|                       |                  |                                                                                       | Ind/Mil<br>(Note 7)                                 |     | 28   | 60   |                         | 7   | 10  | mA   |
|                       | Icc2             | Active Current<br>(CMOS) (EPROM<br>Block Selected)<br>(Notes 2 and 5)                 | Comm'l<br>(Note 6)                                  |     | 16   | 35   |                         | 0   | 0   | mA   |
|                       |                  |                                                                                       | Comm'l<br>(Note 7)                                  |     | 28   | 50   |                         | 0   | 0   | mA   |
|                       |                  |                                                                                       | Ind/Mil<br>(Note 6)                                 |     | 16   | 45   |                         | 0   | 0   | mA   |
|                       |                  |                                                                                       | Ind/Mil<br>(Note 7)                                 |     | 28   | 60   |                         | 0   | 0   | mA   |
|                       |                  | Active Current<br>(CMOS) (SRAM<br>Block Selected<br>(Notes 2and 5)                    | Comm'l<br>(Note 6)                                  |     | 47   | 80   |                         | 7   | 10  | mA   |
|                       | I <sub>CC3</sub> |                                                                                       | Comm'l<br>(Note 7)                                  |     | 59   | 95   |                         | 7   | 10  | mA   |
|                       | 1003             |                                                                                       | Ind/Mil<br>(Note 6)                                 |     | 47   | 100  |                         | 7   | 10  | mA   |
|                       |                  |                                                                                       | Ind/Mil<br>(Note 7)                                 |     | 59   | 115  |                         | 7   | 10  | mA   |
|                       | ILI              | Input Leakage<br>Current                                                              | V <sub>IN</sub> = 5.5 V<br>or GND                   | -1  | ±0.1 | 1    |                         |     |     | μA   |
|                       | ILO              | Output Leakage<br>Current                                                             | V <sub>OUT</sub> = 5.5 V<br>or GND                  | -10 | ±5   | 10   |                         |     |     | μA   |

**NOTES:** 2. CMOS inputs: GND  $\pm$  0.3 V or V<sub>CC</sub>  $\pm$  0.3V. 3. <u>TTL</u> inputs: V<sub>IL</sub>  $\leq$  0.8 V, V<sub>IH</sub>  $\geq$  2.0 V. 4. CSI/A19 is high and the part is in a power-down configuration mode. 5. Add 3.0 mA/MHz for AC power component (power = AC + DC).

6. Ten (10) PAD product terms active. (Add 380 µA per product term, typical, or 480 µA

per product term maximum 7. Forty-one (41) PAD product terms active.

## **PSD313**

## AC Characteristics

|        |                                                                   | -9  | 0   | -1  | 2   | -1      | 5   | -2      | 0   | CMiser = 1 |      |
|--------|-------------------------------------------------------------------|-----|-----|-----|-----|---------|-----|---------|-----|------------|------|
| Symbol | Parameter                                                         | Min | Max | Min | Max | Max Min |     | Min Max |     | Add:       | Unit |
| T1     | ALE or AS Pulse Width                                             | 20  |     | 30  |     | 40      |     | 50      |     | 0          | ns   |
| T2     | Address Set-up Time                                               | 5   |     | 9   |     | 12      |     | 15      |     | 0          | ns   |
| Т3     | Address Hold Time                                                 | 8   |     | 9   |     | 12      |     | 15      |     | 0          | ns   |
| Τ4     | Leading Edge of Read to Data Active                               | 0   |     | 0   |     | 0       |     | 0       |     | 0          | ns   |
| T5     | ALE Valid to Data Valid                                           |     | 100 |     | 130 |         | 160 |         | 200 | 10         | ns   |
| T6     | Address Valid to Data Valid                                       |     | 90  |     | 120 |         | 150 |         | 200 | 10         | ns   |
| Τ7     | CSI Active to Data Valid                                          |     | 100 |     | 130 |         | 160 |         | 200 | 15         | ns   |
| Т8     | Leading Edge of Read to Data Valid                                |     | 32  |     | 38  |         | 55  |         | 60  | 0          | ns   |
| Т9     | Read Data Hold Time                                               | 0   |     | 0   |     | 0       |     | 0       |     | 0          | ns   |
| T10    | Trailing Edge of Read to<br>Data High-Z                           |     | 32  |     | 32  |         | 35  |         | 40  | 0          | ns   |
| T11    | Trailing Edge of ALE or AS to Leading Edge of Write               | 0   |     | 0   |     | 0       |     | 0       |     | 0          | ns   |
| T12    | RD, E, PSEN, or DS<br>Pulse Width                                 | 40  |     | 45  |     | 60      |     | 75      |     | 0          | ns   |
| T12A   | WR Pulse Width                                                    | 20  |     | 25  |     | 35      |     | 45      |     | 0          | ns   |
| T13    | Trailing Edge of Write or<br>Read to Leading Edge<br>of ALE or AS | 0   |     | 0   |     | 0       |     | 0       |     | 0          | ns   |
| T14    | Address Valid to Trailing<br>Edge of Write                        | 90  |     | 120 |     | 150     |     | 200     |     | 0          | ns   |
| T15    | CSI Active to Trailing Edge<br>of Write                           | 100 |     | 130 |     | 160     |     | 200     |     | 0          | ns   |
| T16    | Write Data Set-up Time                                            | 20  |     | 25  |     | 30      |     | 40      |     | 0          | ns   |
| T17    | Write Data Hold Time                                              | 5   |     | 5   |     | 10      |     | 15      |     | 0          | ns   |
| T18    | Port to Data Out Valid<br>Propagation Delay                       |     | 30  |     | 30  |         | 35  |         | 45  | 0          | ns   |
| T19    | Port Input Hold Time                                              | 0   |     | 0   |     | 0       |     | 0       |     | 0          | ns   |
| T20    | Trailing Edge of Write to Port Output Valid                       | 40  |     | 40  |     | 50      |     | 60      |     | 0          | ns   |
| T21    | ADi or Control to CSOi<br>Valid                                   | 6   | 25  | 6   | 30  | 6       | 35  | 5       | 45  | 0          | ns   |
| T22    | ADi or Control to CSOi<br>Invalid                                 | 5   | 25  | 5   | 30  | 4       | 35  | 4       | 45  | 0          | ns   |

## **PSD313**

#### AC Characteristics (Cont.)

|        | _                                                                                     | -9  | 00  | -1  | 2   | -15 |     | -2  | 20  | CMiser = 1 |      |
|--------|---------------------------------------------------------------------------------------|-----|-----|-----|-----|-----|-----|-----|-----|------------|------|
| Symbol | Parameter                                                                             | Min | Max | Min | Max | Min | Max | Min | Max | Add:       | Unit |
| T23    | Track Mode Address<br>Propagation Delay:<br>CSADOUT1 Already True                     |     | 22  |     | 22  |     | 28  |     | 28  | 0          | ns   |
| T23A   | Track Mode Address<br>Propagation Delay:<br>CSADOUT1 Becomes<br>True During ALE or AS |     | 33  |     | 33  |     | 50  |     | 50  | 0          | ns   |
| T24    | Track Mode Trailing Edge<br>of ALE or AS to Address<br>High-Z                         |     | 32  |     | 32  |     | 35  |     | 40  | 0          | ns   |
| T25    | Track Mode Read<br>Propagation Delay                                                  |     | 29  |     | 29  |     | 35  |     | 35  | 0          | ns   |
| T26    | Track Mode Read<br>Hold Time                                                          | 11  | 29  | 11  | 29  | 10  | 29  | 10  | 35  | 0          | ns   |
| T27    | Track Mode Write Cycle,<br>Data Propagation Delay                                     |     | 20  | -   | 20  |     | 30  |     | 30  | 0          | ns   |
| T28    | Track Mode Write<br>Cycle, Write to Data<br>Propagation Delay                         | 8   | 30  | 8   | 30  | 7   | 40  | 7   | 55  | 0          | ns   |
| T29    | Hold Time of Port A<br>Valid During Write<br>CSOi Trailing Edge                       | 2   |     | 2   |     | 2   |     | 2   |     | 0          | ns   |
| T30    | CSI Active to CSOi Active                                                             | 9   | 40  | 9   | 45  | 9   | 50  | 8   | 60  | 0          | ns   |
| T31    | CSI Inactive to CSOi<br>Inactive                                                      | 9   | 40  | 9   | 45  | 9   | 50  | 8   | 60  | 0          | ns   |
| T32    | Direct PAD Input as<br>Hold Time                                                      | 10  |     | 10  |     | 12  |     | 15  |     | 0          | ns   |
| Т33    | $R/\overline{W}$ Active to E or $\overline{DS}$ Start                                 | 20  |     | 20  |     | 30  |     | 40  |     | 0          | ns   |
| T34    | E or $\overline{\text{DS}}$ End to R/ $\overline{\text{W}}$                           | 20  |     | 20  |     | 30  |     | 40  |     | 0          | ns   |
| T35    | AS Inactive to E high                                                                 | 0   |     | 0   |     | 0   |     | 0   |     | 0          | ns   |
| Т36    | Address to Leading<br>Edge of Write                                                   | 20  |     | 20  |     | 25  |     | 30  |     | 0          | ns   |

NOTES: 8. ADi = any address line.

9. CSOi = any of the chip-select output signals coming through Port B (CSO-CS7) or through Port C (CS8-CS10).

10. Direct PAD input = any of the following direct PAD input lines: CSI/A19 as transparent A19, RD/E/DS, WR or R/W, transparent PC0–PC2, ALE (or AS). 11. Control signals RD/E/DS or WR or R/W.

## **PSD313**



See referenced notes on page 144.

## PSD313



See referenced notes on page 144.

## **PSD313**



See referenced notes on page 144.

May, 1993

## **PSD313**



See referenced notes on page 144.

## **PSD313**

#### Figure 5. Chip-Select Output Timing



#### Philips Semiconductors Microcontroller Peripherals

## Field-programmable microcontroller peripheral

## **PSD313**



See referenced notes on page 144.

## **PSD313**



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

#### Notes for Timing Diagrams

- 12. Direct PAD input = any of the following direct PAD input lines: CSI/A19 as transparent A19, RD/E, WR or R/W, transparent PC0–PC2, ALE in non-multiplexed modes.
- 13. Multiplexed inputs: any of the following inputs that are latched by the ALE (or AS): A0/AD0–A15/AD15, CSI/A19 as ALE dependent A19, ALE dependent PC0–PC2.
- CSOi = any of the chip-select output signals coming through Port B (CS0–CS7) or through Port C (CS8–CS10).
- 15. CSADOUT1, which internally enables the address transfer to Port A, should be derived only from direct PAD input signals, otherwise the address propagation delay is slowed down.
- 16. CSADIN and CSADOUT2, which internally enable the data-in or data-out transfers, respectively, can be derived from any combination of direct PAD inputs and multiplexed PAD inputs.
- 17. The write operation signals are included in the CSOi expression.
- Multiplexed PAD inputs: any of the following PAD inputs that are latched by the ALE (or AS) in the multiplexed modes: A11/AD11-A15/AD15, CSI/A19 as ALE dependent A19, ALE dependent PC0-PC2.
- 19. CSOi product terms can include any of the PAD input signals except for reset and CSI.

## Field-programmable microcontroller peripheral

#### **PSD313**

| Pin<br>Capacitance <sup>20</sup> | Symbol | Parameter                                                    | Conditions             | Typical <sup>21</sup> | Max | Unit |
|----------------------------------|--------|--------------------------------------------------------------|------------------------|-----------------------|-----|------|
| Japaonanoc                       | CiN    | Capacitance (for input pins only)                            | V <sub>IN</sub> = 0 V  | 4                     | 6   | pF   |
|                                  | COUT   | Capacitance (for input/output pins)                          | V <sub>OUT</sub> = 0 V | 8                     | 12  | pF   |
|                                  | CVPP   | Capacitance (for WR/V <sub>PP</sub> or R/W/V <sub>PP</sub> ) | V <sub>PP</sub> = 0 V  | 18                    | 25  | pF   |

NOTES: 20. This paramter is only sampled and is not 100% tested.

21. Typical values are for T<sub>A</sub> = 25°C and nominal supply voltages.



**PSD313** 

| Pin<br>Assignments | Pin Name                  | 44-Pin<br>PLCC/CLCC<br>Package |
|--------------------|---------------------------|--------------------------------|
|                    | PSEN                      | 1                              |
|                    | WR/V <sub>PP</sub> or R/W | 2                              |
|                    | RESET                     | 3                              |
|                    | PB7                       | 4                              |
|                    | PB6                       | 5                              |
|                    | PB5                       | 6                              |
|                    | PB4                       | 7                              |
|                    | PB3                       | 8                              |
|                    | PB2                       | 9                              |
|                    | PB1                       | 10                             |
|                    | PB0                       | 11                             |
|                    | GND                       | 12                             |
|                    | ALE or AS                 | 13                             |
|                    | PA7                       | 14                             |
|                    | PA6                       | 15                             |
|                    | PA5                       | 16                             |
|                    | PA4                       | 17                             |
|                    | PA3                       | 18                             |
|                    | PA2                       | 19                             |
|                    | PA1                       | 20                             |
|                    | PA0                       | 21                             |
|                    | RD/E/DS                   | 22                             |
|                    | AD0/A0                    | 23                             |
|                    | AD1/A1                    | 24                             |
|                    | AD2/A2                    | 25                             |
|                    | AD3/A3                    | 26                             |
|                    | AD4/A4                    | 27                             |
|                    | AD5/A5                    | 28                             |
|                    | AD6/A6                    | 29                             |
|                    | AD7/A7                    | 30                             |
|                    | A8                        | 31                             |
|                    | A9                        | 32                             |
|                    | A10                       | 33                             |
|                    | GND                       | 34                             |
|                    | A11                       | 35                             |
|                    | A12                       | 36                             |
|                    | A13                       | 37                             |
|                    | A14                       | 38                             |
|                    | A15                       | 39                             |
|                    | PC0                       | 40                             |
|                    | PC1                       | 41                             |
|                    | PC2                       | 42                             |
|                    | A19/CSI                   | 43                             |
|                    | V <sub>cc</sub>           | 44                             |

#### Philips Semiconductors Microcontroller Peripherals

#### Preliminary specification

## Field-programmable microcontroller peripheral

**PSD313** 



#### Philips Semiconductors Microcontroller Peripherals

## Field-programmable microcontroller peripheral

**PSD313** 

| Ordering<br>Information | Part Number   | Spd.<br>(ns) | Package<br>Type | Package<br>Drawing | Operating<br>Temperature<br>Range | Manufacturing<br>Procedur <del>e</del> |
|-------------------------|---------------|--------------|-----------------|--------------------|-----------------------------------|----------------------------------------|
|                         | PSD313-90 A   | 90           | 44-pin PLCC     | J2                 | Commercial                        | Standard                               |
|                         | PSD313-90 KA  | 90           | 44-pin CLCC     | L4                 | Commercial                        | Standard                               |
|                         | PSD313-12 A   | 120          | 44-pin PLCC     | J2                 | Commercial                        | Standard                               |
|                         | PSD313-12 KA  | 120          | 44-pin CLCC     | L4                 | Commercial                        | Standard                               |
|                         | PSD313-15 A   | 150          | 44-pin PLCC     | J2                 | Commercial                        | Standard                               |
|                         | PSD313-15I A  | 150          | 44-pin PLCC     | J2                 | Industrial                        | Standard                               |
|                         | PSD313-15 KA  | 150          | 44-pin CLCC     | L4                 | Commercial                        | Standard                               |
|                         | PSD313-15I KA | 150          | 44-pin CLCC     | L4                 | Industrial                        | Standard                               |
|                         | PSD313-20 A   | 200          | 44-pin PLCC     | J2                 | Commercial                        | Standard                               |
|                         | PSD313-201 A  | 200          | 44-pin PLCC     | J2                 | Industrial                        | Standard                               |
|                         | PSD313-20 KA  | 200          | 44-pin CLCC     | L4                 | Commercial                        | Standard                               |
|                         | PSD313-20I KA | 200          | 44-pin CLCC     | L4                 | Industrial                        | Standard                               |

**Philips Semiconductors** 

## Section 2 PSD3XXL Family

PSD3XXL Programmable Microcontroller Peripherals

#### INDEX

| PSD3XXL<br>Family     | 3-volt single-chip<br>microcontroller peripherals151                                    |
|-----------------------|-----------------------------------------------------------------------------------------|
| PSD301 <sup>®</sup> L | 3-volt single-chip<br>microcontroller peripheral<br>(x8/x16; 256Kb EPROM, 16Kb SRAM)181 |
| PSD311L               | 3-volt single-chip<br>microcontroller peripheral<br>(x8; 256Kb EPROM, 16Kb SRAM)203     |
| PSD302L               | 3-volt single-chip<br>microcontroller peripheral<br>(x8/x16; 512Kb EPROM, 16Kb SRAM)221 |
| PSD312L               | 3-volt single-chip<br>microcontroller peripheral<br>(x8; 512Kb EPROM, 16Kb SRAM)243     |
| PSD303L               | 3-volt single-chip<br>microcontroller peripheral<br>(x8/x16; 1Mb EPROM, 16Kb SRAM)261   |
| PSD313L               | 3-volt single-chip<br>microcontroller peripheral<br>(x8; 1Mb EPROM, 16Kb SRAM)283       |

PSD301 is a registered trademark of WaferScale Integration, Inc.

#### **Key Features**

- Eliminates mixing and matching discrete low-voltage parts
- 3.0 to 5.5 volt operation
- 19 Individually Configurable I/O pins that can be used as:
- Microcontroller I/O port expansion
- Programmable Address Decoder (PAD) I/O
- Latched address output
- Open drain or CMOS
- Two Programmable Arrays (PAD A & PAD B)
- Direct Address Decoding up to 1 Meg address space
- Logic replacement of discrete lowvoltage PALs<sup>®</sup>
- 256Kb to 1Mb of EPROM
- 16Kb of SRAM
- "No Glue" Microcontroller Chip-Set
- Built-in address latches for multiplexed address/data bus
- Non-multiplexed address/data bus mode
- ALE polarity programmable
- Selectable modes for read and write control

- 250 ns access time, including input latches and PAD address decoding.
- Built-In Page Logic
- To Expand the Microcontroller Address Space
- Up to 16 1Mb pages
- Address/Data Track Mode
- Enables easy Interface to Shared Resources (e.g., Mail Box SRAM) with other Microcontrollers or a Host Processor
- CMiser-Bit
- Programmable option to further reduce power consumption
- Built-In Security Bit
- Locks the Device and PAD Decoding Configuration
- Available in a Choice of Packages
- 44 Pin PLDCC or CLDCC
- Simple Menu-Driven Software: Configure the Device on an IBM PC

| Part                  | PLD<br>Inputs/<br>Product<br>Terms | Ports | EPROM<br>Size | SRAM<br>Size | Configuration | Memory<br>Paging | C-Miser<br>Bit | Security<br>Bit |
|-----------------------|------------------------------------|-------|---------------|--------------|---------------|------------------|----------------|-----------------|
| PSD301 <sup>®</sup> L | 14/40                              | 19    | 256 Kb        | 16 Kb        | x8 or x16     |                  | x              | х               |
| PSD311L               | 14/40                              | 19    | 256 Kb        | 16 Kb        | x8            |                  | х              | х               |
| PSD302L               | 18/40                              | 19    | 512 Kb        | 16 Kb        | x8 or x16     | x                | x              | x               |
| PSD312L               | 18/40                              | 19    | 512 Kb        | 16 Kb        | x8            | х                | х              | x               |
| PSD303L               | 18/40                              | 19    | 1 Mb          | 16 Kb        | x8 or x16     | х                | х              | x               |
| PSD313L               | 18/40                              | 19    | 1 Mb          | 16 Kb        | x8            | х                | X              | x               |

*PSD3XXL Family Feature Summary* 

| 3-volt single-ch                                       | nip microcontroller peripherals                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | PSD3XXL Family                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Partial Listing<br>of<br>Microcontrollers<br>Supported | <ul> <li>Motorola family:<br/>M6805, M68HC11, M68HC16,<br/>M68000/10/20, M60008, M683XX</li> <li>Intel family:<br/>8031/8051, 8096/8098, 80186/88,<br/>80196/98</li> <li>Signetics:<br/>SC80C451, SC80552</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                    | <ul> <li>TI:<br/>SC80C451, TMS320C14</li> <li>Zilog:<br/>Z8, Z80, Z180</li> <li>National:<br/>HPC16000, HPC46400</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                      |
| Applications                                           | <ul> <li>Computers (Notebook and Portable PCs)</li> <li>Fixed Disk Control, Modem, Imaging,<br/>Laser Printer Control</li> <li>Telecommunications</li> <li>Modem, Cellular Phone, Digital PBX,<br/>Digital Speech, FAX,<br/>Digital Signal Processing</li> </ul>                                                                                                                                                                                                                                                                                                                                                        | <ul> <li>Portable Industrial Equipment</li> <li>Measurement Meters, Data Recorders</li> <li>Medical Instrumentation</li> <li>Hearing Aids, Monitoring Equipment,<br/>Diagnostic Tools</li> </ul>                                                                                                                                                                                                                                                                                                                                 |
| Introduction                                           | The PSD3XXL Series offers the latest<br>members in the rapidly growing family of<br>PSD devices. They are the market's first<br>low-voltage single-chip solution for<br>microcontroller-based applications where<br>consistent specifications for design, fast<br>time-to-market, small form factor, and low<br>power consumptions are essential. When<br>combined in an 8- or 16-bit system, virtually<br>any microcontroller (68HC11, 8051, 80186,<br>etc.) and the PSD3XXL device work<br>together to create a very powerful chip-set<br>solution. This implementation eliminates<br>mixing and matching low voltage | specifications for various discrete<br>components. It also provides all the<br>required control and peripheral elements<br>needed in a microcontroller-based system<br>with no external discrete "glue" logic<br>required.<br>The solution comes complete with simple<br>system software development tools for<br>integrating the PSD3XXL with the<br>microcontroller. Hosted on IBM PC<br>platforms or compatibles, the easy to use<br>software enables the designer to quickly<br>configure the device and use it immediately. |

PSD301 is a registered trademark of WaterScale Integration, Inc. PAL is a registered trademark of Advanced Micro Devices, Inc.

#### Product Description

The PSD3XXL family integrates high performance user-configurable blocks of EPROM, SRAM, and programmable logic. The major functional blocks include two programmable logic arrays, PAD A and PAD B. 256K to 1Mbit of EPROM. 16K bits of SRAM, input latches, and output ports. The PSD3XXL family is ideal for applications requiring low power and very small form factors. These include hard disk control, modems, cellular telephones, instrumentation, computer peripherals, military and similar applications. Designers do not have to identify discrete devices at low voltages and then attempt to normalize specifications and operation at 3.3 V.

The PSD3XXL family offers a unique single-chip solution for microcontrollers that need:

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

WSI's PSD3XXL Family Architecture (Figure 1) can efficiently interface with, and enhance, any low-voltage 8- or 16-bit microcontroller system. This is the first solution that provides microcontrollers with port expansion, latched addresses, page logic, two programmable logic arrays (PAD A and PAD B), an interface to shared resources, 256K, 512K or 1M bit EPROM, and 16K bit SRAM on a single chip – all operating at 3.3 V in one package. The PSD3XXL family does not require any glue logic for interfacing to any 8- or 16-bit microcontroller. The 8051 microcontroller family can take full advantage of the PSD3XXL's separate program and data address spaces. Users of the 68HCXX microcontroller family can change the functionality of the control signals and directly connect the R/W and E, or the R/W and DS signals. (Users of 16-bit microcontrollers, including the 80186, 8096, 80196 and 16XXX, can use the PSD301L/302L/303L in a 16-bit configuration). Address and data buses can be configured as separate or multiplexed, whichever is required by the host processor.

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

The page register extends the accessible address space of certain microcontrollers from 64 K to 1 M. There are 16 pages that can serve as base address inputs to the PAD, thereby enlarging the address space of 16 address line microcontrollers by a factor of 16.

vescript



## **PSD3XXL** Family

| Table 1.<br>PSD3XXL Pin | Name                                            | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------------------------|-------------------------------------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Descriptions            | BHE/PSEN<br>(PSD30XL<br>Devices)<br>or          | Ι    | When the data bus width is 8 bits (CDATA = 0), this pin is $\overrightarrow{PSEN}$ . In this mode, $\overrightarrow{PSEN}$ is the active low EPROM read pulse. The SRAM and I/O ports read signal is generated according to the description of the WR/V <sub>PP</sub> or R/W and $\overrightarrow{RD/E/DS}$ pins. If the host processor is a member of the 8031 family, $\overrightarrow{PSEN}$ must be connected to the corresponding host pin. In other 8-bit host processors that do not have a special EPROM-only read strobe, $\overrightarrow{PSEN}$ should be tied to V <sub>CC</sub> . In this case, $\overrightarrow{RD}$ or E and $\overrightarrow{R/W}$ provide the read strobe for the SRAM, I/O ports, and EPROM. When the data bus width is configured as 16 (CDATA = 1), this pin is BHE. When BHE is low, data bus bits D8–D15 are read from, or written into, the PSD3XXL, depending on the operation being read or write, respectively. In programming mode, this pin is pulsed between V <sub>PP</sub> and 0. |
|                         | PSEN<br>(PSD31XL<br>Devices<br>Only)            | I    | The PSEN is the active low EPROM read pulse. The SRAM and I/O ports read signal is generated according to the description of the WR/V <sub>PP</sub> or R/W, and RD/E pins. If the host processor is a member of the 8031 family, PSEN must be connected to the corresponding host pin. In other 8-bit host processors that do not have a special EPROM-only read strobe, PSEN should be tied to V <sub>CC</sub> . In this case, RD or E and R/W provide the read strobe for the SRAM, I/O ports, and EPROM.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                         | WR/V <sub>PP</sub><br>or<br>R/W/V <sub>PP</sub> | 1    | In the operating mode, this pin's function is $\overline{WR}$ (CRRWR = 0) or<br>R/W (CRRWR = 1) when configured as R/W. The following tables<br>summarize the read and write operations (CRRWR = 1):<br>$\begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                         | RD/E/DS<br>(Note 2)<br>or<br>RD/E<br>(Note 3)   |      | The pin function depends on the CRRWR and CEDS configuration<br>bits. If CRRWR = 0, RD is an active low read pulse. When<br>CRRWR = 1, this pin and the R/W pin define the following cycle type:<br>If CEDS = 0, E is an active high strobe. If CEDS = 1, DS is an active<br>low strobe.<br>When configured as $\overline{RD}$ (CRRWR = 0), this pin provides an active<br>low RD strobe. When configured as E (CRRWR = 1), this pin<br>becomes an active high pulse, which, together with R/W defines the<br>cycle type. Then, if R/W = 1 and E = 1, a read operation is executed.<br>If R/W = 0 and E = 1, a write operation is executed.                                                                                                                                                                                                                                                                                                                                                                                      |

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

- **NOTE:** 1. All the configuration bits mentioned in Table 1 appear in parentheses and are explained in the Configuration Register section.
  - 2. PSD302L/312L/303L/313L only.

3. PSD301L/311L only.

| Table 1.<br>PSD3XXL Pin                | Name                                                 | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------------------------------|------------------------------------------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PSDSXXL FIN<br>Descriptions<br>(Cont.) | CSI/A19                                              | 1    | This pin has two configurations. When it is $\overline{CSI}$ (CA19/ $\overline{CSI}$ = 0) and<br>the pin is asserted high, the device is deselected and powered<br>down. (See Tables 12 and 13 for the chip state during power-down<br>mode.) If the pin is asserted low, the chip is in normal operational<br>mode. When it is configured as A19, (CA19/ $\overline{CSI}$ = 1), this pin can<br>be used as an additional input to the PAD. CADLOG3 = 1 defines<br>the pin as an address; CADLOG3 = 0 defines it as a logic input. If it<br>is an address, A19 can be latched with ALE (CADDHLT = 1) or be<br>a transparent logic input (CADDHLT = 0). In this mode, there is no<br>power-down capability.                                                                                                                                                                                      |
|                                        | RESET                                                | I    | Reset is an active low pin. To reset the part, see Figure 10b. Also see Tables 10a, 10b and 11 for the chip state during and after reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                        | ALE<br>or<br>AS                                      | -    | In the multiplexed modes, the ALE pin functions as an Address<br>Latch Enable or as an Address strobe and can be configured as<br>an active high or active low signal. The ALE or AS trailing edge<br>latches lines AD15/A15–AD0/A0 and A16–A19 in 16-bit mode<br>(AD7/A7–AD0/A0 and A16–A19 in 8-bit mode) and BHE,<br>depending on the PSD3XXL configuration. See Table 8. In the<br>non-multiplexed modes, it can be used as a general-purpose<br>logic input to the PAD.                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                        | PA7<br>PA6<br>PA5<br>PA4<br>PA3<br>PA2<br>PA1<br>PA0 | I/O  | PA7–PA0 is an 8-bit port that can be configured to track<br>AD7/A7–AD0/A0 from the input (CPAF2 = 1). Otherwise<br>(CPAF2 = 0), each bit can be configured separately as an I/O or<br>lower-order latched address line. When configured as an I/O<br>(CPAF1 = 0), the direction of the pin is defined by its direction bit,<br>which resides in the direction register. If a pin is an I/O output, its<br>data bit (which resides in the data register) comes out. When it is<br>configured as a low-order address line (CPAF1 = 1), A7–A0<br>can be made the corresponding output through this port (e.g., PA6<br>can be configured to be the A6 address line). Each port bit<br>can be a CMOS output (CPACOD = 0) or an open drain output<br>(CPACOD = 1). When the chip is in non-multiplexed mode<br>(CADDRAT = 0), the port becomes the data bus lines (D0–D7).<br>See Figure 4.           |
|                                        | PB7<br>PB6<br>PB5<br>PB4<br>PB3<br>PB2<br>PB1<br>PB0 | 1/0  | PB7–PB0 is an 8-bit port for which each bit can be configured as<br>an I/O (CPBF = 1) or chip-select output (CPBF = 0). Each port bit<br>can be a CMOS output (CPBCOD = 0) or an open drain output<br>(CPBCOD = 1). When configured as an I/O, the direction of the<br>pin is defined by its direction bit, which resides in the direction<br>register. If a pin is an I/O output, its data (which resides in the data<br>register) comes out. When configured as a chip-select output,<br>$\overline{CS0}$ – $\overline{CS3}$ are a function of up to four product terms of the inputs to<br>the PAD B; $\overline{CS4}$ ,– $\overline{CS7}$ then are each a function of up to two<br>product terms. On the PSD301L/302L/303L, when the chip is in<br>non-multiplexed mode (CADDRAT = 0) and the data bus width is<br>16 (CDATA = 1), the port becomes the data bus (D8–D15).<br>See Figure 6. |

| Table 1.<br>PSD3XXL Pin | Name                                                                                     | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------------------------|------------------------------------------------------------------------------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Descriptions<br>(Cont.) | PC0<br>PC1<br>PC2                                                                        | I/O  | This is a 3-bit port for which each bit is configurable as a PAD A<br>and B input or output. When configured as an input (CPCF = 0),<br>a bit individually becomes an address (CADLOG = 1) or a logic<br>input (CADLOG = 0). The addresses can be latched with ALE<br>(CADDHLT = 1) or be transparent inputs to the PADs<br>(CADDHLT = 0). When a pin is configured as an output (CPCF = 1),<br>it is a function of one product term of all PAD inputs.<br>See Figure 7. |
|                         | AD0/A0<br>AD1/A1<br>AD2/A2<br>AD3/A3<br>AD4/A4<br>AD5/A5<br>AD6/A6<br>AD7/A7             | 1/0  | In multiplexed mode, these pins are the multiplexed low-order<br>address/data byte. After ALE latches the addresses, these<br>pins input or output data, depending on the settings of the RD/E<br>(RD/E/DS on the PSD302L/303L), WR/V <sub>PP</sub> or R/W, and BHE/PSEN<br>pins. In non-multiplexed mode, these pins are the low-order<br>address input.                                                                                                                |
|                         | AD8/A8<br>AD9/A9<br>AD10/A10<br>AD11/A11<br>AD12/A12<br>AD13/A13<br>AD14/A14<br>AD15/A15 | I/O  | In 16-bit multiplexed mode, these pins are the multiplexed<br>high-order address/data byte. After ALE latches the addresses, these<br>pins input or output data, depending on the settings of the $\overline{RD}/E$ or<br>$\overline{RD}/E/DS$ , $\overline{WR}/V_{PP}$ or $R/\overline{W}$ , and $\overline{BHE}/PSEN$ pins. In all other modes,<br>these pins are the high-order address input.                                                                        |
|                         | GND                                                                                      | Р    | V <sub>SS</sub> (ground) pin.                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                         | V <sub>cc</sub>                                                                          | Р    | Supply voltage input.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

PSD3XXL Family

## 3-volt single-chip microcontroller peripherals

Operating Modes

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

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

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

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

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

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

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

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

#### Non-Multiplexed Address/Data, 16-bit Data Bus

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

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

#### Philips Semiconductors Microcontroller Peripherals

## 3-volt single-chip microcontroller peripherals

## **PSD3XXL** Family



## *PSD3XXL Port Configurations* (x8 Only)



**Legend:** AD8–AD15 = Addresses A8–A15 multiplexed with data lines D8–D15. AD0–AD7 = Addresses A0–A7 multiplexed with data lines D0–D7. Table 2. PSD30XL Bus and Port Configuration Options

## 3-volt single-chip microcontroller peripherals

**PSD3XXL** Family

|                 | Multiplexed Address/Data                                                        | Non-Multiplexed Address/Data |
|-----------------|---------------------------------------------------------------------------------|------------------------------|
| 8-bit Data Bus  |                                                                                 |                              |
| Port A          | I/O or low-order address<br>lines or Low-order multiplexed<br>address/data byte | D0–D7 data bus byte          |
| Port B          | I/O or CS0-CS7                                                                  | I/O and/or CS0CS7            |
| AD0/A0-AD7/A7   | Low-order multiplexed address/data byte                                         | Low-order address bus byte   |
| AD8/A8-AD15/A15 | High-order multiplexed<br>address data byte                                     | High-order address bus byte  |
| 16-bit Data Bus |                                                                                 |                              |
| Port A          | I/O or low-order address<br>lines or Low-order multiplexed<br>address/data byte | Low-order data bus byte      |
| Port B          | I/O or CS0-CS7                                                                  | High-order data bus byte     |
| AD0/A0-AD7/A7   | Low-order multiplexed<br>address/data byte                                      | Low-order address bus byte   |
| AD8/A8-AD15/A15 | High-order multiplexed address/data byte                                        | High-order address bus byte  |

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

#### *Programmable Address Decoder (PAD)*

The PSD3XXL consists of two programmable arrays referred to as PAD A and PAD B (Figure 3). PAD A is used to generate chip select signals derived from the input address to the internal EPROM blocks, SRAM, I/O ports, and Track Mode signals. All its I/O functions are listed in Table 3 and shown in Figure 3. PAD B outputs to Ports B and C for off-chip usage.

PAD B can also be used to extend the decoding to select external devices or as a random logic replacement. The input bus to

both PAD A and PAD B is the same. Using MAPLE software, each programmable bit in the PAD's array can have one of three logic states of 0, 1, and don't care (X). In a user's logic design, both PADs can share the same inputs using the X for input signals that are not supposed to affect other functions. The PADs use reprogrammable CMOS EPROM technology and can be programmed and erased by the user.



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

- 5. RESET deselects all PAD output signals. See Tables 10 and 11.
- 6. A18, A17, and A16 are internally multiplexed with CS10, CS9, and CS8, respectively. Either A18 or CS10, A17 or CS9, and A16 or CS8 can be routed to the external pins of Port C. Port C can be configured as either input or output.
- 7. P0-P3 are not included on PSD3X1L devices.

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

PSD3XXL Family

## 3-volt single-chip microcontroller peripherals

#### Configuration Bits

The configuration bits shown in Table 4 are non-volatile cells that let the user set the device, I/O, and control functions to the proper operational mode. Table 5 lists all configuration bits. The configuration bits are programmed and verified during the programming phase. In operational mode, they are not accessible. To simplify implementing a specific mode, use the PSD3XXL MAPLE software to set the bits.

#### Table 4. PSD3XXL Non-Volatile Configuration Bits

| Use This Bit       | То                                                                                                                                                                               |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CDATA              | Set the data bus width to 8 or 16 bits (PSD30XL only).                                                                                                                           |
| CADDRDAT           | Set the address/data buses to multiplexed or non-multiplexed mode.                                                                                                               |
| CEDS               | Determine the polarity and functionality of read and write. (Note 9)                                                                                                             |
| CA19/CSI           | Set A19/CSI to CSI (power-down) or A19 input.                                                                                                                                    |
| CALE               | Set the ALE polarity.                                                                                                                                                            |
| CPAF2              | Set Port A either to track the low-order byte of the address/data multiplexed bus or to select the I/O or address option.                                                        |
| CSECURITY          | Set the security on or off (a secured part can not be duplicated).                                                                                                               |
| COMB/SEP           | Set PSEN and RD for combined or separate address spaces (see Figures 9 and 10).                                                                                                  |
| CPAF1<br>(8 Bits)  | Configure each pin of Port A in multiplexed mode to be an I/O or address out.                                                                                                    |
| CPACOD<br>(8 Bits) | Configure each pin of Port A as an open drain or active CMOS pull-up output.                                                                                                     |
| CPBF<br>(8 Bits)   | Configure each pin of Port B as an I/O or a chip-select output                                                                                                                   |
| CPBCOD<br>(8 Bits) | Configure each pin of Port B as an open drain or active CMOS pull-up output.                                                                                                     |
| CPCF<br>(3 Bits)   | Configure each pin of Port C as an address input or a chip-select output.                                                                                                        |
| CADDHLT            | Configure pins A16 – A19 to go through a latch or to have their latch transparent.                                                                                               |
| CADLOG<br>(4 Bits) | Configure A16 – A19 individually as logic or address inputs.<br>(Note 9)                                                                                                         |
| CATD               | Configure pins A16–A19 as PAD logic inputs or high-order address inputs (Note 8).                                                                                                |
| CLOT               | Determine in non-multiplexed mode if address inputs are transparent or latched (Note 9).                                                                                         |
| CRRWR              | Set the $\overline{RD}/E$ and $\overline{WR}/V_{PP}$ or $\overline{R/W}$ pins to $\overline{RD}$ and $\overline{WR}$ pulse, or to E strobe and $\overline{R/W}$ status (Note 8). |
| CRRWR              | Configure the polarity and control methods of read and write cycles. (Note 9)                                                                                                    |
| CMISER             | Controls the lower-power mode.                                                                                                                                                   |

NOTES: 8. PSD31XL only.

9. PSD302L/312L/303L/313L only.

**Port Functions** 

The PSD3XXL has three I/O ports (Ports A, B, and C) that are configurable at the bit level. This permits great flexibility and a high degree of customization for specific applications. The following is a description of each port. Figure 4 shows the pin structure of Port A.



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



**NOTE:** 11. The expression for CSADOUT2 must include the following write operation cycle signals: For CRRWR = 0, CSADOUT2 must include WR = 0. For CRRWR = 1, CSADOUT2 must include E = 1 and RW = 0.

| Table 5.<br>PSD3XXL                    | Configuration<br>Bits      | No.<br>of Bits | Function                                                                                                                                                                                                                                                  |
|----------------------------------------|----------------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Configuration<br>Bits <sup>12,13</sup> | CDATA<br>(Note 14)         | 1              | 8-bit or 16-bit Data Bus Width<br>CDATA = 0 eight bits<br>CDATA = 1 sixteen bits                                                                                                                                                                          |
|                                        | CADDRDAT                   | 1              | ADDRESS/DATA Multiplexed (separate buses)<br>CADDRDAT = 0, non-multiplexed<br>CADDRDAT = 1, multiplexed                                                                                                                                                   |
|                                        | CA19/CSI                   | 1              | A19 or CSI<br>CA19/CSI = 0, enable power-down<br>CA19/CSI = 1, enable A19 input to PAD                                                                                                                                                                    |
|                                        | CALE                       | 1              | Active HIGH or Active LOW<br>CALE = 0, Active high<br>CALE = 1, Active low                                                                                                                                                                                |
|                                        | COMB/SEP                   | 1              | Combined or Separate Address Space<br>for SRAM and EPROM<br>0 = Combined, 1 = Separate                                                                                                                                                                    |
|                                        | CPAF1                      | 8              | Port A I/Os or A0–A7<br>CPAF1 = 0, Port A pin = I/O<br>CPAF1 = 1, Port A pin = A0 – A7                                                                                                                                                                    |
|                                        | CPAF2                      | 1              | Port A AD0-AD7 (address/data multiplexed bus)<br>CPAF2 = 0, address or I/O on Port A (according to CPAF1)<br>CPAF2 = 1, address/data multiplexed on Port A (track mode)                                                                                   |
|                                        | CATD<br>(Note 16)          | 1              | A16–A19 address or logic inputs<br>CATD = 0, logic inputs<br>CATD = 1, address inputs                                                                                                                                                                     |
|                                        | CADDHLT                    | 1              | A16–A19 Transparent or Latched<br>CADDHLT = 0, Address latch transparent<br>CADDHLT = 1, Address latched (ALE dependent)                                                                                                                                  |
|                                        | CSECURITY                  | 1              | SECURITY On/Off<br>CSECURITY = 0, off<br>CSECURITY = 1, on                                                                                                                                                                                                |
|                                        | CLOT<br>(Note 15)          | 1              | A0–A15 Address Inputs are transparent or<br>ALE-dependent in non-multiplexed modes<br>CLOT = 0, transparent<br>CLOT = 1, ALE-dependent                                                                                                                    |
|                                        | CRRWR<br>CEDS<br>(Note 15) | 2              | Determine the polarity and control methods of read and write cycles.         CEDS       CRRWR         0       0       RD and WR active low pulses         0       1       R/W status and high E pulse         1       1       R/W status and low DS pulse |
|                                        | CRRWR<br>(Note 16)         | 1              | CRRWR = 0, $\overline{RD}$ and $\overline{WR}$ active low strobes<br>CRRWR = 1, R/W status and E active high pulse                                                                                                                                        |
|                                        | CPACOD                     | 8              | Port A CMOS or Open Drain Output<br>CPACOD = 0, CMOS output<br>CPACOD = 1, open-drain output                                                                                                                                                              |
|                                        | CPBF                       | 8              | Port B is I/O or $\overline{CS0}$ – $\overline{CS7}$<br>CPBF = 0, Port B pin is $\overline{CS0}$ – $\overline{CS7}$<br>CPBF = 1, Port B pin is I/O                                                                                                        |

## **PSD3XXL** Family

| Configuration<br>Bits | No.<br>of Bits | Function                                                                                                                                                                     |
|-----------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CPBCOD                | 8              | Port B CMOS or Open Drain<br>CPBCOD = 0, CMOS output<br>CPBCOD = 1, open-drain output                                                                                        |
| CPCF                  | 3              | Port C A16–A18 or $\overline{CS8}$ – $\overline{CS10}$<br>CPCF = 0, Port C pin is A16–A18<br>CPCF = 1, Port C pin is $\overline{CS8}$ – $\overline{CS10}$                    |
| CADLOG<br>(Note 15)   | 4              | Port C: A16–A19 Address or Logic Input<br>CADLOG = 0, Port C pin or A19/ $\overline{CSI}$ is logic input<br>CADLOG = 1, Port C pin or A19/ $\overline{CSI}$ is address input |
| CMISER                | 1              | Default: CMISER = 0<br>CMISER = 1, lower-power mode                                                                                                                          |

NOTES: 12. WSI's Maple software will guide the user to the proper configuration choice.

13. In an unprogrammed or erased part, all configuration bits are 0.

14. PSD30XL only.

15. PSD3X2L/3X3L only.

16. PSD3X1L only.

#### Port Functions (Cont.)

Table 5. PSD3XXL Configuration Bits (Cont.)

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

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

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

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

## **PSD3XXL** Family

## 3-volt single-chip microcontroller peripherals

#### Port Functions (Cont.)

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

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

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

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

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

#### *Port B in 16-Bit Non-Multiplexed Address/Data Mode (PSD30XL)*

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

#### Accessing the I/O Port Registers

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

#### Port C in All Modes

Each pin of Port C (shown in Figure 7) can be configured as an input to PAD A and PAD B or output from PAD B. As inputs, the pins are named A16-A18. Although the pins are given names of the high-order address bus, they can be used for any other address lines or logic inputs to PAD A and PAD B. For example, A8-A10 can also be connected to those pins, improving the boundaries of CS0-CS7 resolution to 256 bytes. As inputs, they can be individually configured to be logic or address inputs. A logic input uses the PAD only for Boolean equations that are implemented in any or all of the CS0-CS10 PAD B outputs. Port C addresses can be programmed to latch the inputs by the trailing edge ALE or to be transparent.

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

#### ALE/AS and AD0/AO-AD15/A15 in Non-Multiplexed Modes

In non-multiplexed modes, AD0/A0-AD15/A15 are address inputs only and can become transparent (CLOT = 0) or ALE dependent (CLOT = 1). In transparent mode, the ALE/AS pin can be used as an additional logic input to the PADs. The nonmultiplexed ALE dependent mode is useful in applications for which the host processor has a multiplex address/data bus and AD0/A0-AD7/A7 are not multiplexed with A0-A7 but rather are multiplexed with other address lines. In these applications, Port A serves as a data bus and each of its pins can be directly connected to the corresponding host's multiplexed pin, where that data bit is expected. (See Table 8.)

## **PSD3XXL** Family



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

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

| <i>Table 7.<br/>I/O Port<br/>Addresses in a</i> | Register Name                       | Word Size Access of the I/O Port Registers<br>Offset from the CSIOPORT |  |
|-------------------------------------------------|-------------------------------------|------------------------------------------------------------------------|--|
| 16-bit Data Bus                                 | Pin Register of Ports B and A       | + 2 (accessible during read operation only)                            |  |
| Mode <sup>18,19</sup>                           | Direction Register of Ports B and A | + 4                                                                    |  |
| (PSD30XL)                                       | Data Register of Ports B and A      | +6                                                                     |  |

NOTES: 18. When the data bus width is 16, Port B registers can only be accessed if the BHE signal is low.

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

## **PSD3XXL** Family



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

 PSD3X2L/3X3L: Individual pins can be configured independently as address or logic inputs (CADLOG, bits 0–2).

PSD3X1L: All Port C pins are either address or logic inputs (CATD).

#### Port Functions (Cont.)

#### ALE/AS and ADO/AO–AD15/A15 in Non-Multiplexed Modes (PSD302L/303L)

In non-multiplexed modes,

AD0/A0-AD15/A15 are address inputs only and can become transparent (CLOT = 0) or ALE dependent (CLOT = 1). In transparent mode, the ALE/AS pin can be used as an additional logic input to the PADs. The nonmultiplexed ALE dependent mode is useful in applications for which the host processor has a multiplex address/data bus and AD0/A0-AD7/A7 are not multiplexed with A0-A7 but rather are multiplexed with other address lines. In these applications, Port A serves as a data bus and each of its pins can be directly connected to the corresponding host's multiplexed pin, where that data bit is expected. (See Table 8.)

#### ALE/AS and ADO/AO–AD7/A7 in Non-Multiplexed Modes (PSD31XL)

In non-multiplexed modes, A0-A15 are address inputs only and can become transparent (CLOT = 0) or ALE dependent (CLOT = 1). In transparent mode, the ALE/AS pin can be used as an additional logic input to the PADs. The non-multiplexed ALE dependent mode is useful in applications for which the host processor has a multiplex address/data bus and AD0/A0-AD7/A7 are not multiplexed with A0-A7 but rather are multiplexed with other address lines. In these applications, Port A serves as a data bus and each of its pins can be directly connected to the corresponding host's multiplexed pin, where that data bit is expected. (See Table 8.)

## **PSD3XXL** Family

| A16–A19<br>Inputs | If one or more of the pins PC0, PC1 PC2<br>and $\overline{CSI}/A19$ are configured as inputs, the<br>configuration bits CADDHLT and CATD<br>define their functionality inside the part.<br>CADDHLT determines if these inputs are to<br>be latched by the trailing edge of the<br>ALE or AS signal (CADDHLT = 1), or<br>enabled into the PSD3XX at all times<br>(CADDHLT = 0, transparent mode). CATD | determines whether these lines are high-<br>order address lines, that take part in the<br>derivation of memory and I/O select<br>signals inside the chip (CATD = 1), or logic<br>input lines that have no impact on memory<br>or I/O selections (CATD = 0). Logic input<br>lines typically participate in the Boolean<br>expressions implemented in the PAD. |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | CADDHLT determines if these inputs are to<br>be latched by the trailing edge of the<br>ALE or AS signal (CADDHLT = 1), or<br>enabled into the PSD3XX at all times                                                                                                                                                                                                                                     | input lines that have no impact on memory<br>or I/O selections (CATD = 0). Logic input<br>lines typically participate in the Boolean                                                                                                                                                                                                                         |

#### **EPROM**

The EPROM has 8 banks of memory. Each bank can be placed in any address location by programming the PAD. Bank0–Bank7 is selected by PAD outputs ES0-ES7, respectively.

| Device  | EPROM<br>Size |          | EPROM<br>Architecture |         | <b>EPROM Bank<br/>Architecture<br/>(8 ea)</b> |  |
|---------|---------------|----------|-----------------------|---------|-----------------------------------------------|--|
|         |               | x8       | x16                   | x8      | x16                                           |  |
| PSD301L | 256Kb         | 32K x 8  | 16K x 16              | 4K x 8  | 2K x 16                                       |  |
| PSD311L | 256Kb         | 32K x 8  | _                     | 4K x 8  | -                                             |  |
| PSD302L | 512Kb         | 64K x 8  | 32K x 16              | 8K x 8  | 4K x 16                                       |  |
| PSD312L | 512Kb         | 64K x 8  | _                     | 8K x 8  | -                                             |  |
| PSD303L | 1Mb           | 128K x 8 | 64K x 16              | 16K x 8 | 8K x 16                                       |  |
| PSD313L | 1Mb           | 128K x 8 | _                     | 16K x 8 | -                                             |  |

#### SRAM

Each PSD3XXL device has 16K bits of SRAM. Depending on the configuration of the data bus, the SRAM organization can

be 2K x 8 (8-bit data bus) or 1K x 16 (16-bit data bus). The SRAM is selected by the RS0 output of the PAD.

# Memory Paging<br/>(PSD3X2L/3X3L)The page register consists of four<br/>flip-flops, which can be read from, or<br/>written to, through the I/O address space<br/>(CSIOPORT). The page register is<br/>connected to the D3–D0 lines. The Page<br/>Register address is CSIOPORT + 18H. Thepage register outputs are P3–P0, which are<br/>fed into the PAD. This enables the host<br/>microcontroller to enlarge its address<br/>space by a factor of 16 (there can be a<br/>maximum of 16 pages). See Figure 8.

## **PSD3XXL** Family



Table 8. Signal Latch Status in All Operating Modes

| Signal<br>Name      | Configuration<br>Bits             | Configuration<br>Mode                                             | Signal Latch<br>Status |
|---------------------|-----------------------------------|-------------------------------------------------------------------|------------------------|
|                     | CDATA , CADDRDAT, CLOT = 0        | 8-bit data.                                                       | Transparent            |
|                     | CDATA, CADDRDAT = 0, CLOT = 1     | non-multiplexed                                                   | ALE<br>Dependent       |
|                     | CDATA = 1, CADDRDAT, CLOT = 0     | 16-bit data.                                                      | Transparent            |
| AD8/A8-<br>AD15/A15 | CDATA = 1, CADDRDAT = 0, CLOT = 1 | non-multiplexed                                                   | ALE<br>Dependent       |
|                     | CDATA = 0, CADDRDAT = 1           | 8-bit data,<br>multiplexed                                        | Transparent            |
|                     | CDATA = 1, CADDRDAT = 1           | 16-bit data,<br>multiplexed                                       | ALE<br>Dependent       |
|                     | CADDRDAT = 0, CLOT = 0            | non-multiplexed                                                   | Transparent            |
| AD0/A0-<br>AD7/A7   | CADDRDAT = 0, CLOT = 1            | modes                                                             | ALE<br>Dependent       |
|                     | CADDRDAT = 1                      | multiplexed modes                                                 | ALE<br>Dependent       |
|                     | CDATA = 0                         | 8-bit data,<br>PSEN is active                                     | Transparent            |
| <u>BHE/</u><br>PSEN | CDATA = 1, CADDRDAT = 0           | 16-bit data,<br>non-multiplexed<br><u>mod</u> e,<br>BHE is active | Transparent            |
|                     | CDATA = 1, CADDRDAT = 1           | 16-bit data,<br>multiplexed mode,<br>BHE is active                | ALE<br>Dependent       |
| A19 and<br>PC2-PC0  | CADDHLT = 0                       | A16-A19 can<br>become logic inputs                                | Transparent            |
|                     | CADDHLT = 1                       | A16–A19 can<br>become<br>multiplexed<br>address lines             | ALE<br>Dependent       |

#### **Control Signals**

The PSD3XXL control signals are WR/V<sub>PP</sub> or R/W, RD/E or RD/E/DS, ALE, BHE/PSEN or PSEN, RESET, and A19/CSI. Each of these signals can be configured to meet the output control signal requirements of various microcontrollers.

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

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

#### RD/E/DS (or RD/E on PSD3X1L)

In operational mode, this signal can be configured as RD, E, or DS. As RD, all read operations are activated by an active low signal on this pin. As E, the pin operates with the R/W signal of the WR/V<sub>PP</sub> or R/W pin. When R/W is high, an active high signal on the RD/E/DS pin performs a read operation. When R/W is low, an active high signal on the RD/E/DS pin performs a write operation.

As  $\overline{\text{DS}}$ , the pin functions with the R/W signal as an active low data strobe signal. As  $\overline{\text{DS}}$ , the R/W defines the mode of operation (Read or Write).

#### ALE or AS

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

#### BHE/PSEN

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

Whenever a member of the 8031 family (or any other similar microcontroller) is used, the PSEN pin must be connected to the PSEN pin of the microcontroller.

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

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

#### RESET

This is an asynchronous input pin that clears and initializes the part. For the PSD3XXL, reset is a low signal only. Whenever the reset input is driven low for at least 500 ns, the chip is reset. After reset becomes high, the chip will be operational only after an additional 500 ns. See Figure 11. Note that during boot-up, the part is not automatically reset internally and does require an external reset. Tables 10a, 10b and 11 indicate the state of the part during and after reset.

## **PSD3XXL** Family

**PSD3XXL** Family

## 3-volt single-chip microcontroller peripherals

| Control Signals | A19/CSI   |
|-----------------|-----------|
| (Cont.)         | When co   |
|                 | dessionts |

When configured as  $\overline{CSI}$ , a high on this pin deselects, and powers down, the chip. A low on this pin puts the chip in normal operational mode. For PSD3XXL states during the power-down mode, see Tables 12 and 13, and Figure 12. In A19 mode, the pin is an additional input to the PAD. It can be used as an address line (CADLOG3 = 1) or as a generalpurpose logic input (CADLOG3 = 0). A19 can be configured as ALE dependent or as transparent input (see Table 8). In this mode, the chip is always enabled.



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

## **PSD3XXL** Family



| Table 10a.<br>Signal States | Signal           | Condition |  |
|-----------------------------|------------------|-----------|--|
| During Reset                | AD0/A0-AD15/A15  | Input     |  |
| Cycle (RESET)               | PA0-PA7 (Port A) | Input     |  |
|                             | PB0-PB7 (Port B) | Input     |  |
|                             | PC0-PC2 (Port C) | Input     |  |

| Table 10b.                         | Signal              | Configuration Mode                                                      | Condition                   |
|------------------------------------|---------------------|-------------------------------------------------------------------------|-----------------------------|
| Signal States<br>After Reset Cycle | AD0/A0-AD7/A7       | All                                                                     | Input                       |
|                                    | A8-A15              | All                                                                     | Input                       |
| (RESET)                            | PA0–PA7)<br>(Port A | I/O<br>Tracking AD0/A0–AD7<br>Address outputs A0–A7                     | Input<br>Input<br>Low       |
|                                    | PB0PB7<br>(Port B)  | I/O<br><u>CS7–CS0</u> CMOS outputs<br><u>CS7–CS0</u> open drain outputs | Input<br>High<br>Tri-stated |
|                                    | PC0–PC2<br>(Port C) | Address inputs A16–A18<br>CS8–CS10 CMOS outputs                         | Input<br>High               |

## **PSD3XXL** Family



| <i>Table 11.<br/>Internal States<br/>During and After<br/>Reset Cycle</i> | Component                                                                          | Signals                                                    | Contents          |
|---------------------------------------------------------------------------|------------------------------------------------------------------------------------|------------------------------------------------------------|-------------------|
|                                                                           |                                                                                    | <u>CS0–CS10</u>                                            | All = 1 (Note 13) |
|                                                                           | PAD                                                                                | CSADIN, CSADOUT1,<br>CSADOUT2, CSIOPORT,<br>RS0, ES0 – ES7 | All = 0 (Note 13) |
|                                                                           | Data register A<br>Direction register A<br>Data register B<br>Direction register B | n/a<br>n/a<br>n/a<br>n/a                                   | 0<br>0<br>0<br>0  |

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



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

**PSD3XXL** Family

| Table 12a. Signal               | Signal          | Configuration Mode                                                                        | Condition                          |
|---------------------------------|-----------------|-------------------------------------------------------------------------------------------|------------------------------------|
| States During                   | AD0/A0-AD15/A15 | All                                                                                       | Input                              |
| Power-Down<br>Mode<br>(PSD30XL) | PA0-PA7         | I/O<br>Tracking AD0/A0–AD7/A7<br>Address outputs A0–A7                                    | Unchanged<br>Input<br>All 1's      |
|                                 | PB0PB7          | I/O<br><u>CS0</u> – <u>CS7</u> CMOS outputs<br><u>CS0</u> – <u>CS7</u> open drain outputs | Unchanged<br>All 1's<br>Tri-stated |
|                                 | PC0-PC2         | Address inputs A18–A16<br>CS8–CS10 CMOS outputs                                           | Input<br>All 1's                   |

| Table 12b.                     | Signal        | Configuration Mode                                        | Condition                          |
|--------------------------------|---------------|-----------------------------------------------------------|------------------------------------|
| Signal States<br>During Power- | AD0/A0-AD7/A7 | All                                                       | Input                              |
| own Mode                       | A8-A15        | All                                                       | Input                              |
| PSD31XL)                       | PA0-PA7       | I/O<br>Tracking AD0/A0-AD7/A7<br>Address outputs A0-A7    | Unchanged<br>Input<br>All 1's      |
|                                | PB0-PB7       | I/O<br>CS0–CS7 CMOS outputs<br>CS0–CS7 open drain outputs | Unchanged<br>All 1's<br>Tri-stated |
|                                | PC0-PC2       | Address inputs A18–A16<br>CS8–CS10 CMOS outputs           | Input<br>All 1's                   |

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

### **PSD3XXL** Family



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

CEDS

0

In Figure 13, the PSD3XXL is configured to System In Figure 14, the PSD3XXL is configured to interface with Intel's 80C31, which is a 16interface with Motorola's 68HC11, which **Applications** bit address/8-bit data bus microcontroller. is a 16-bit address/8-bit data bus Its data bus is multiplexed with the lowmicrocontroller. Its data bus is multiplexed order address byte. The 80C31 uses with the low-order address byte. The signals RD to read from data memory and 68HC11 uses E and R/W signals to derive PSEN to read from code memory. It uses the read and write strobes. It uses the term WR to write into the data memory. It also AS (address strobe) for the address latch uses active high reset and ALE signals. pulse. RESET is an active low signal. The The rest of the configuration bits as well as rest of the configuration bits as well as the the unconnected signals (not shown) are unconnected signals (not shown) are application specific and, thus, user specific and, thus, user dependent. dependent.

## **PSD3XXL Family**



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

*System Applications* (Cont.) In Figure 15, the PSD3XXL is configured to work directly with Intel's 80C196KB microcontroller, which is a 16-bit address/16-bit data bus processor. Address and data lines multiplexed. In the example shown, all configuration bits are set. The PSD3XXL is configured to use PC0, PC1, PC2, and CSI/A19 as A16, A17, A18, and A19 inputs, respectively. These signals are independent of the ALE pulse (latchtransparent). They are used as four general-purpose logic inputs that take part in the PAD equations implementation. Port A is configured to work in the special track mode, in which (for certain conditions) PA0–PA7 tracks lines AD0/A0–AD7/A7. Port B is configured to generate CS0–CS7. In this example, PB2 serves as a WAIT signal that slows down the 80C196KB during the access of external peripherals. These 8-bit wide peripherals are connected to the shared bus of Port A. The WAIT signal also drives the buswidth input of the microcontroller, so that every external peripheral cycle becomes an 8-bit data bus cycle. PB3 and PB4 are open-drain output signals; thus, they are pulled up externally.

#### Philips Semiconductors Microcontroller Peripherals

#### 3-volt single-chip microcontroller peripherals

### **PSD3XXL** Family

#### Figure 15. PSD3XXL Interface With Intel's 80C196KB.



The configuration bits for Figure 15 are:

| CALE     | 0          |
|----------|------------|
| CDATA    | 1          |
| CADDRDAT | 1          |
| CPAF1    | Don't care |
| CPAF2    | 1          |
| CA19/CSI | 1          |
| CRRWR    | 0          |
| COMB/SEP | 0          |
| CADDHLT  | 0          |
|          |            |

| CSECURITY           | Don't care |
|---------------------|------------|
| CPCF2, CPCF1, CPCF0 | 0, 0, 0    |
| CPACOD7-CPACOD0     | 00H        |
| CPBF7-CPBF0         | 00H        |
| CPBCOD7-CPBCOD0     | 18H        |
| CEDS                | 0          |
| CADLOG3—CADLOG0     | 0H         |

lower current, and is reflected in the data

sheet. This mode has an adder in

propagation delay in T5, T6, and T7 parameters in the A.C. Characteristics, and should be added to compute worst-case timing requirements in the application.

#### **PSD3XXL** Family 3-volt single-chip microcontroller peripherals Security Security Mode in the PSD3XX locks the software. In window packages, the mode is contents of the PAD A, PAD B and all the erasable through UV full part erasure. In Mode configuration bits. The EPROM, SRAM, the security mode, the PSD3XX contents cannot be copied on a programmer. and I/O contents can be accessed only through the PAD. The Security Mode can be set by the MAPLE or Programming **CMiser-Bit** The CMiser-Bit provides a programmable In the default mode, or if the PSD3XX is option for power-sensitive applications that configured without programming the require further reduction in power CMiser-Bit (CMiser = 0), the device operates at specified speed and power consumption. The CMiser-Bit (CMiser = 1) in the Maple portion of the PSD3XX sytem rating as specified in the A.C. and D.C. Characteristics. development software can be used to reduce power consumption. The CMiser-However, if the CMiser-Bit is programmed Bit turns off the EPROM blocks in the (CMiser = 1), the device consumes even PSD3XX whenever the EPROM is not

accessed, thereby reducing the active

current consumed by the PSD3XX.

180

#### **Key Features**

- Single Chip Programmable Peripheral for Microcontroller-based Applications
- 3.0 to 5.5 Volt Operation
- 19 Individually Configurable I/O pins that can be used as:
- Microcontroller I/O port expansion
- Programmable Address Decoder (PAD) I/O
- Latched address output
- Open drain or CMOS
- Two Programmable Arrays (PAD A and PAD B)
- Total of 40 Product Terms and up to 14 Inputs and 24 Outputs
- Address Decoding up to 1 MB
- Logic replacement
- "No Glue" Microcontroller Chip-Set
- Built-in address latches for multiplexed address/data bus
- Non-multiplexed address/data bus mode
- Selectable 8 or 16 bit data bus width
- ALE and Reset polarity programmable
- Selectable modes for read and write control bus as RD/WR or R/W/E
- BHE pin for byte select in 16-bit mode
- PSEN pin for 8051 users

- 256 Kbits of UV EPROM
- Configurable as 32K x 8 or as 16K x 16
- Divides into 8 equal mappable blocks for optimized mapping
- Block resolution is 4K x 8 or 2K x 16
- 250 ns EPROM access time, including input latches and PAD address decoding.
- 16 Kbit Static RAM
- Configurable as 2K x 8 or as 1K x 16
- 250 ns SRAM access time, including input latches and PAD address decoding
- Address/Data Track Mode
- Enables easy Interface to Shared Resources (e.g., Mail Box SRAM) with other Microcontrollers or a Host Processor
- Built-In Security
- Locks the PSD301L and PAD Decoding Configuration
- Available in a Choice of Packages
- 44 Pin PLDCC and CLDCC
- Simple Menu-Driven Software: Configure the PSD301L on an IBM PC
- Pin Compatible with the PSD3XX and PSD3XXL Series

Absolute Maximum Ratings<sup>1</sup>

## 3-volt single-chip microcontroller peripheral

## PSD301L

| Symbol           | Parameter                     | Condition           | Min   | Max   | Unit |
|------------------|-------------------------------|---------------------|-------|-------|------|
| т                | Storage Temperature           | CERAMIC             | - 65  | + 150 | °C   |
| T <sub>STG</sub> | Storage remperature           | PLASTIC             | - 65  | + 125 | °C   |
| T <sub>STG</sub> | Storage Temperature           |                     | - 65  | + 150 | °C   |
|                  | Voltage on any Pin            | With Respect to GND | - 0.6 | + 7   | V    |
| V <sub>PP</sub>  | Programming<br>Supply Voltage | With Respect to GND | - 0.6 | + 14  | v    |
| V <sub>cc</sub>  | Supply Voltage                | With Respect to GND | - 0.6 | + 7   | V    |
|                  | ESD Protection                |                     |       | >2000 | V    |

NOTE: 1. Stresses above those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to Absolute Maximum Rating conditions for extended periods of time may affect device reliability.

| Operating<br>Range | Range      | Temperature   | V <sub>CC</sub> |
|--------------------|------------|---------------|-----------------|
|                    | Commercial | 0° C to +70°C | 3.0 to 5.5 V    |

| Recommended<br>Operating<br>Conditions | Symbol          | Parameter                | Conditions                                 | Min                 | Тур | Max                    | Unit |
|----------------------------------------|-----------------|--------------------------|--------------------------------------------|---------------------|-----|------------------------|------|
|                                        | V <sub>cc</sub> | Supply Voltage           | All Speeds                                 | 3.0                 | 3.3 | 5.5                    | V    |
| oonuntions                             | V <sub>IH</sub> | High-level Input Voltage | $V_{CC} = 3.0 \text{ V to } 5.5 \text{ V}$ | 0.7 V <sub>CC</sub> |     | V <sub>CC</sub> + 0.5  | V    |
|                                        | V               | Low lovel input Veltage  |                                            | - 0.5               |     | 0.2 V <sub>CC</sub> *  | V    |
|                                        | VIL             | Low-level Input Voltage  | $v_{\rm CC} = 3.0 \ v \ 10 \ 5.5 \ v$      | -0.5                |     | 0.3 V <sub>CC</sub> ** | V    |

\*Before 8/1/1993.

\*\* After 8/1/1993.

DC

**Characteristics** 

## 3-volt single-chip microcontroller peripheral

PSD301L

|                  |                                                                                           |                                                     |     |      |     |     | Miser<br>btraci | -   |      |
|------------------|-------------------------------------------------------------------------------------------|-----------------------------------------------------|-----|------|-----|-----|-----------------|-----|------|
| Symbol           | Parameter                                                                                 | Conditions                                          | Min | Тур  | Max | Min | Тур             | Max | Unit |
| V <sub>OL</sub>  | Output Low                                                                                | I <sub>OL</sub> = 20 μA<br>V <sub>CC</sub> = 3.0 V  |     | 0.01 | 0.1 |     |                 |     | v    |
| νοι              | Voltage                                                                                   | I <sub>OL</sub> = 4 mA<br>V <sub>CC</sub> = 3.0 V   |     | 0.15 | 0.4 |     |                 |     | v    |
| V <sub>OH</sub>  | Output High                                                                               | I <sub>OH</sub> = -20 μA<br>V <sub>CC</sub> = 3.0 V | 2.9 | 2.99 |     |     |                 |     | v    |
| · 0n             | Voltage                                                                                   | I <sub>OH</sub> = -1 mA<br>V <sub>CC</sub> = 3.0 V  | 2.4 | 2.6  |     |     |                 |     | v    |
|                  | V <sub>CC</sub> Standby                                                                   | N 00V                                               |     | 10*  | 25* |     |                 |     |      |
| I <sub>SB1</sub> | SB1 Current (CMOS) V <sub>C</sub><br>(Notes 2 and 3)                                      | V <sub>CC</sub> = 3.3 V                             |     | 1**  | 5** |     |                 |     | μA   |
|                  | Cc1 Active Current<br>(CMOS) (No<br>Internal Memory<br>Block Selected)<br>(Notes 2 and 5) | V <sub>CC</sub> = 3.3 V<br>(Note 5)                 |     | 6    | 12  |     | 3.0             | 5   | mA   |
| ICC1             |                                                                                           | V <sub>CC</sub> = 3.3 V<br>(Note 6)                 |     | 10   | 20  |     | 3.0             | 5   | mA   |
| I <sub>CC2</sub> | Active Current<br>(CMOS) (EPROM<br>Block Selected)                                        | V <sub>CC</sub> = 3.3 V<br>(Notes 5<br>and 7)       |     | 6    | 12  |     | 0               | 0   | mA   |
|                  | (Notes 2 and 5)                                                                           | V <sub>CC</sub> = 3.3 V<br>(Note 6<br>and 7)        |     | 10   | 20  |     | 0               | 0   | mA   |
| I <sub>CC3</sub> | Active Current<br>(CMOS) (SRAM                                                            | V <sub>CC</sub> = 3.3 V<br>(Note 5<br>and 7)        |     | 20   | 33  |     | 3               | 5   | mA   |
| •003             | Block Selected)<br>(Notes 2 and 5)                                                        | V <sub>CC</sub> = 3.3 V<br>(Notes 6<br>and 7)       |     | 24   | 40  |     | 3               | 5   | mA   |
| ILI              | Input Leakage<br>Current                                                                  | V <sub>IN</sub> = V <sub>CC</sub><br>or GND         | -1  | ±0.1 | 1   |     |                 |     | μΑ   |
| ILO              | Output Leakage<br>Current                                                                 | V <sub>OUT</sub> = V <sub>CC</sub><br>or GND        | -10 | ±5   | 10  |     |                 |     | μΑ   |

NOTES: 2. CMOS inputs: GND  $\pm$  0.3 V or V<sub>CC</sub>  $\pm$  0.3V.

3. CSI/A19 is high and the part is in a power-down configuration mode.

- 4. Add 2.0 mA/MHz for AC power component (power = AC + DC).
- 5. Ten (10) PAD product terms active. (Add 190  $\mu A$  per product term, typical, or 240  $\mu A$  per product term maximum.)

6. Forty (40) PAD product terms active.

7. In 8-bit mode, an additional 3 mA Max can be saved under CMiser.

\*Before 8/1/1993.

\*\* After 8/1/1993.

## PSD301L



The Normalized Supply Current vs. Supply Voltage graph shown above, provides a multiplier for any  $I_{SB}$  or  $I_{CC}$  value in the D.C. Characteristics table. As noted, it is normalized for a supply voltage of 3.3 volts. Since device characterization data shows very little supply current difference over speed, the multiplier includes all frequencies of operation from standby to quiescent to full dynamic speed. To use, calculate the supply current at 3.3 volts for your operation configuration using the D.C. Characteristics table. Then multiply that value by the Supply Current Multiplier for the supply voltage actually being used.

#### PSD301L

| AC<br>Characteristics <sup>(8)</sup><br>(See Timing<br>Diagrams) | Symbol | Para                    |
|------------------------------------------------------------------|--------|-------------------------|
| Diagrams)                                                        | T1     | ALE or A                |
|                                                                  | T2     | Address                 |
|                                                                  | Т3     | Address                 |
|                                                                  | T4     | Leading<br>to Data A    |
|                                                                  | T5     | ALE Vali                |
|                                                                  | T6     | Address                 |
|                                                                  | 77     | CSI Activ               |
|                                                                  | Т8     | Leading<br>to Data \    |
|                                                                  | Т9     | Read Da                 |
|                                                                  | T10    | Trailing E<br>to Data H |
|                                                                  | T11    | Trailing E<br>to Leadir |
|                                                                  | T12    | RD, E, P                |
|                                                                  | T12A   | WR Puls                 |
|                                                                  | T13    | Trailing E<br>to Leadir |
|                                                                  | T14    | Address<br>Edge of      |
|                                                                  | T15    | CSI Activ<br>of Write   |
|                                                                  |        |                         |

|        |                                                                                       | -2  | 25  | -3  | 80  |                      |      |
|--------|---------------------------------------------------------------------------------------|-----|-----|-----|-----|----------------------|------|
| Symbol | Parameter                                                                             | Min | Max | Min | Max | CMiser = 1<br>Add:** | Unit |
| T1     | ALE or AS Pulse Width                                                                 | 75  |     | 80  |     |                      | ns   |
| T2     | Address Set-up Time                                                                   | 30  |     | 35  |     |                      | ns   |
| Т3     | Address Hold Time                                                                     | 30  |     | 35  |     | 0                    | ns   |
| T4     | Leading Edge of Read to Data Active                                                   | 0   |     | 0   |     | 0                    | ns   |
| T5     | ALE Valid to Data Valid                                                               |     | 250 |     | 300 | 25                   | ns   |
| T6     | Address Valid to Data Valid                                                           |     | 250 |     | 300 | 25                   | ns   |
| 77     | CSI Active to Data Valid                                                              |     | 275 |     | 325 | 30                   | ns   |
| Т8     | Leading Edge of Read to Data Valid                                                    |     | 90  |     | 95  | 0                    | ns   |
| Т9     | Read Data Hold Time                                                                   | 0   |     | 0   |     | 0                    | ns   |
| T10    | Trailing Edge of Read to Data High-Z                                                  |     | 50  |     | 55  | 0                    | ns   |
| T11    | Trailing Edge of ALE or AS to Leading Edge of Write                                   |     | 40  |     | 45  |                      | ns   |
| T12    | RD, E, PSEN, DS Pulse Width                                                           | 100 |     | 110 |     | 0                    | ns   |
| T12A   | WR Pulse Width                                                                        | 90  |     | 95  |     | 0                    | ns   |
| T13    | Trailing Edge of Write or Read to Leading Edge of ALE or AS                           | 0   |     | 0   |     | 0                    | ns   |
| T14    | Address Valid to Trailing<br>Edge of Write                                            | 250 |     | 300 |     | 0                    | ns   |
| T15    | CSI Active to Trailing Edge<br>of Write                                               | 275 |     | 375 |     | 0                    | ns   |
| T16    | Write Data Set-up Time                                                                | 60  |     | 65  |     | 0                    | ns   |
| T17    | Write Data Hold Time                                                                  | 25  |     | 30  |     | 0                    | ns   |
| T18    | Port to Data Out Valid<br>Propagation Delay                                           |     | 70  |     | 75  | 0                    | ns   |
| T19    | Port Input Hold Time                                                                  | 0   |     | 0   |     | 0                    | ns   |
| T20    | Trailing Edge of Write to Port<br>Output Valid                                        | 100 |     | 110 |     | 0                    | ns   |
| T21    | ADi or Control to CSOi Valid                                                          | 6   | 80  | 5   | 85  | 0                    | ns   |
| T22    | ADi or Control to CSOi Invalid                                                        | 4   | 80  | 4   | 85  | 0                    | ns   |
| T23    | Track Mode Address Propagation<br>Delay: CSADOUT1 Already True                        |     | 70  |     | 75  | 0                    | ns   |
| T23A   | Track Mode Address<br>Propagation Delay:<br>CSADOUT1 Becomes True<br>During ALE or AS |     | 100 |     | 110 | 0                    | ns   |
| T24    | Track Mode Trailing Edge of ALE<br>or AS to Address High-Z                            |     | 60  |     | 65  | 0                    | ns   |

**NOTE:** 8. These AC Characteristics are for  $V_{CC} = 3.0 - 3.6V$ .

## 3-volt single-chip microcontroller peripheral

PSD301L

| AC                                 |        |                                                              | -2  | 25  | -3  | 0   |                      |      |
|------------------------------------|--------|--------------------------------------------------------------|-----|-----|-----|-----|----------------------|------|
| <i>Characteristics<br/>(Cont.)</i> | Symbol | Parameter                                                    | Min | Max | Min | Max | CMiser = 1<br>Add:** | Unit |
|                                    | T24    | Track Mode Trailing Edge of ALE<br>or AS to Address High-Z   |     | 60  |     | 65  | 0                    | ns   |
|                                    | T25    | Track Mode Read Propagation<br>Delay                         |     | 70  |     | 75  | 0                    | ns   |
|                                    | T26    | Track Mode Read Hold Time                                    | 10  | 70  | 10  | 75  |                      | ns   |
|                                    | T27    | Track Mode Write Cycle,<br>Data Propagation Delay            |     | 60  |     | 65  | 0                    | ns   |
|                                    | T28    | Track Mode Write Cycle,<br>Write to Data Propagation Delay   | 7   | 80  | 7   | 85  | 0                    | ns   |
|                                    | T29    | Hold Time of Port A Valid<br>During Write CSOi Trailing Edge | 4   |     | 4   |     | 0                    | ns   |
|                                    | T30    | CSI Active to CSOi Active                                    | 9   | 110 | 8   | 120 | 0                    | ns   |
|                                    | T31    | CSI Inactive to CSOi Inactive                                | 9   | 110 | 8   | 120 | 0                    | ns   |
|                                    | T32    | Direct PAD Input as Hold Time                                | 24  |     | 30  |     | 0                    | ns   |
|                                    | T33    | R/W Active to E or DS Start                                  | 60  |     | 65  |     | 0                    | ns   |
|                                    | T34    | E or DS End to R/W                                           | 60  |     | 65  |     | 0                    | ns   |
|                                    | T35    | AS Inactive to E high                                        | 40  |     | 45  |     | 0                    | ns   |
|                                    | Т36    | Address to Leading Edge of Write                             | 50  |     | 60  |     | 0                    | ns   |

NOTES: 9. <u>ADi =</u> any address line.

10. CSOi = any of the chip-select output signals coming through Port B (CSO-CS7) or through Port C (CS8-CS10).

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

12. Control signals RD/E/DS or WR or R/W.

\*\*After 8/1/1993.

#### Philips Semiconductors Microcontroller Peripherals

#### Preliminary specification

## 3-volt single-chip microcontroller peripheral



#### PSD301L





#### Philips Semiconductors Microcontroller Peripherals

## 3-volt single-chip microcontroller peripheral

### PSD301L





#### PSD301L





#### Philips Semiconductors Microcontroller Peripherals

## 3-volt single-chip microcontroller peripheral

### PSD301L

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



## PSD301L



#### Philips Semiconductors Microcontroller Peripherals

### 3-volt single-chip microcontroller peripheral

#### PSD301L



#### PSD301L





### PSD301L

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





#### Philips Semiconductors Microcontroller Peripherals

#### 3-volt single-chip microcontroller peripheral

### PSD301L



PSD301L



#### Figure 15. Port A as ADO – AD7 Timing (Track Mode), CRRWR = 1

Notes for Timing Diagrams

- Direct PAD input = any of the following direct PAD input lines: CSI/A19 as transparent A19, RD/E/DS, WR or R/W, transparent PC0–PC2, ALE in non-multiplexed modes.
- 14. Multiplexed inputs: any of the following inputs that are latched by the ALE (or AS): A0/AD0–A15/AD15, CSI/A19 as ALE dependent A19, ALE dependent PC0–PC2.
- CSOi = any of the chip-select output signals coming through Port B (CS0–CS7) or through Port C (CS8–CS10).
- 16. CSADOUT1, which internally enables the address transfer to Port A, should be derived only from direct PAD input signals, otherwise the address propagation delay is slowed down.
- 17. CSADIN and CSADOUT2, which internally enable the data-in or data-out transfers, respectively, can be derived from any combination of direct PAD inputs and multiplexed PAD inputs.
- 18. The write operation signals are included in the  $\overline{\text{CSOi}}$  expression.
- Multiplexed PAD inputs: any of the following PAD inputs that are latched by the ALE (or AS) in the multiplexed modes: A11/AD11-A15/AD15, CSI/A19 as ALE dependent A19, ALE dependent PC0-PC2.

20. CSOi product terms can include any of the PAD input signals except for reset and CSI.

PSD301L

#### Pin Capacitance<sup>21</sup>

 $T_A=25\,^\circ C,\,f=1\,\,MHz$ 

| Symbol | Parameter                           | <b>Conditions</b>      | Typical <sup>22</sup> | Max | Unit |
|--------|-------------------------------------|------------------------|-----------------------|-----|------|
| CIN    | Capacitance (for input pins only)   | V <sub>IN</sub> = 0 V  | 4                     | 6   | pF   |
| COUT   | Capacitance (for input/output pins) | V <sub>OUT</sub> = 0 V | 8                     | 12  | pF   |
| CVPP   | Capacitance (for WR/VPP or R/W/VPP) | V <sub>PP</sub> = 0 V  | 18                    | 25  | pF   |

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

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

#### Erasure and Programming

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

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

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

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





Ordering Information

## 3-volt single-chip microcontroller peripheral

| Part Number  | Spd.<br>(ns) | Package<br>Type | Package<br>Drawing | Operating<br>Temperature<br>Range | Manufacturing<br>Procedure |
|--------------|--------------|-----------------|--------------------|-----------------------------------|----------------------------|
| PSD301L25 A  | 250          | 44-pin PLCC     | J2                 | Commercial                        | Standard                   |
| PSD301L25 KA | 250          | 44-pin CLCC     | L4                 | Commercial                        | Standard                   |
| PSD301L30 A  | 300          | 44-pin PLCC     | J2                 | Commercial                        | Standard                   |
| PSD301L30 KA | 300          | 44-pin CLCC     | L4                 | Commercial                        | Standard                   |

#### Preliminary specification

## 3-volt single-chip microcontroller peripheral

## PSD311L

### Key Features

- Single Chip Programmable Peripheral for Microcontroller-based Applications
- 3.0 to 5.5 Volt Operation
- 19 Individually Configurable I/O pins that can be used as:
- Microcontroller I/O port expansion
- Programmable Address Decoder (PAD) I/O
- Latched address output
- Open drain or CMOS
- Two Programmable Arrays (PAD A and PAD B)
- Total of 40 Product Terms and up to 14 Inputs and 24 Outputs
- Address Decoding up to 1 Meg address space
- Logic replacement
- "No Glue" Microcontroller Chip-Set
- Built-in address latches for multiplexed address/data bus
- Non-multiplexed address/data bus mode
- 8-bit data bus width
- ALE and Reset polarity programmable
- Selectable modes for read and write control bus as RD/WR or R/W/E
- PSEN pin for 8051 users

- 256 Kbits of UV EPROM
- Organized as 32K x 8
- Divides into 8 equal mappable blocks for optimized mapping
- Block resolution is 4K x 8
- 250 ns EPROM access time, including input latches and PAD address decoding.
- 16 Kbit Static RAM
- Organized as 2K x 8
- 250 ns SRAM access time, including input latches and PAD address decoding
- Address/Data Track Mode
- Enables easy Interface to Shared Resources (e.g., Mail Box SRAM) with other Microcontrollers or a Host Processor
- Built-In Security
- Locks the PSD311L and PAD Decoding Configuration
- □ Available in a Choice of Packages
- 44 Pin PLDCC and CLDCC
- Simple Menu-Driven Software: Configure the PSD311L on an IBM PC
- Pin Compatible with the PSD3XX and PSD3XXL Series

## PSD311L

| Absolute                        | Symbol                   | Parameter                     | <b>Condition</b>    | Min   | Max   | Unit |
|---------------------------------|--------------------------|-------------------------------|---------------------|-------|-------|------|
|                                 | T <sub>STG</sub>         | Storage Temperature           | CERAMIC             | - 65  | + 150 | °C   |
| Maximum<br>Ratings <sup>1</sup> | TSTG Clorage remperature | PLASTIC                       | - 65                | + 125 | °C    |      |
|                                 | T <sub>STG</sub>         | Storage Temperature           |                     | - 65  | + 150 | °C   |
|                                 |                          | Voltage on any Pin            | With Respect to GND | - 0.6 | +7    | V    |
|                                 | V <sub>PP</sub>          | Programming<br>Supply Voltage | With Respect to GND | - 0.6 | + 14  | v    |
|                                 | V <sub>cc</sub>          | Supply Voltage                | With Respect to GND | - 0.6 | +7    | V    |
|                                 |                          | ESD Protection                |                     |       | >2000 | V    |

**NOTE:** 1. Stresses above those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to Absolute Maximum Rating conditions for extended periods of time may affect device reliability.

| Operating<br>Pango | Range      | Temperature   | V <sub>CC</sub> |  |
|--------------------|------------|---------------|-----------------|--|
| Range              | Commercial | 0° C to +70°C | 3.0 V to 5.5 V  |  |

| Recommended                           | Symbol          | Parameter                | Conditions                                 | Min                 | Тур | Max                    | Unit |
|---------------------------------------|-----------------|--------------------------|--------------------------------------------|---------------------|-----|------------------------|------|
| <i>Operating</i><br><i>Conditions</i> | V <sub>cc</sub> | Supply Voltage           | All Speeds                                 | 3.0                 | 3.3 | 5.5                    | V    |
| oonantions                            | VIH             | High-level Input Voltage | $V_{CC} = 3.0 \text{ V to } 5.5 \text{ V}$ | 0.7 V <sub>CC</sub> |     | V <sub>CC</sub> + 0.5  | V    |
|                                       | , v             |                          |                                            | 0.5                 |     | 0.2 V <sub>CC</sub> *  | V    |
|                                       | Vi∟             | Low-level Input Voltage  | V <sub>CC</sub> = 3.0 V to 5.5 V           | - 0.5               |     | 0.3 V <sub>CC</sub> ** | v    |

\* Before 8/1/1993.

\*\* After 8/1/1993.

4

DC

**Characteristics** 

## 3-volt single-chip microcontroller peripheral

PSD311L

|                  |                                                                                           |                                                     |     |      |     |     | Miser<br>btract | -   |      |
|------------------|-------------------------------------------------------------------------------------------|-----------------------------------------------------|-----|------|-----|-----|-----------------|-----|------|
| Symbol           | Parameter                                                                                 | <b>Conditions</b>                                   | Min | Тур  | Max | Min | Тур             | Max | Unit |
| V <sub>OL</sub>  | Output Low                                                                                | l <sub>OL</sub> = 20 μA<br>V <sub>CC</sub> = 3.0 V  |     | 0.01 | 0.1 |     |                 |     | v    |
| ·0L              | Voltage                                                                                   | I <sub>OL</sub> = 4 mA<br>V <sub>CC</sub> = 3.0 V   |     | 0.15 | 0.4 |     |                 |     | v    |
| V <sub>OH</sub>  | Output High                                                                               | I <sub>OH</sub> = -20 μA<br>V <sub>CC</sub> = 3.0 V | 2.9 | 2.99 |     |     |                 |     | v    |
| *OH              | Voltage                                                                                   | l <sub>OH</sub> = -1 mA<br>V <sub>CC</sub> = 3.0 V  | 2.4 | 2.6  |     |     |                 |     | v    |
|                  | V <sub>CC</sub> Standby                                                                   | V 0.0.V                                             |     | 10*  | 25* |     |                 |     |      |
| I <sub>SB1</sub> | Current (CMOS)<br>(Notes 2 and 3)                                                         | V <sub>CC</sub> = 3.3 V                             |     | 1**  | 5** |     |                 |     | μA   |
| 1                | CC1 Active Current<br>(CMOS) (No<br>Internal Memory<br>Block Selected)<br>(Notes 2 and 5) | V <sub>CC</sub> = 3.3 V<br>(Note 5)                 |     | 6    | 12  |     | 3.0             | 5   | mA   |
| 'CC1             |                                                                                           | V <sub>CC</sub> = 3.3 V<br>(Note 6)                 |     | 10   | 20  |     | 3.0             | 5   | mA   |
| I <sub>CC2</sub> | Active Current<br>(CMOS) (EPROM                                                           | V <sub>CC</sub> = 3.3 V<br>(Note 5)                 |     | 6    | 12  |     | 2               | 3   | mA   |
| .002             | Block Selected)<br>(Notes 2 and 5)                                                        | V <sub>CC</sub> = 3.3 V<br>(Note 6)                 |     | 10   | 20  |     | 2               | 3   |      |
| I <sub>CC3</sub> | Active Current<br>(CMOS) (SRAM                                                            | V <sub>CC</sub> = 3.3 V<br>(Note 5)                 |     | 20   | 33  |     | 5               | 8   | mA   |
| 000              | Block Selected)<br>(Notes 2 and 5)                                                        | V <sub>CC</sub> = 3.3 V<br>(Note 6)                 |     | 24   | 40  |     | 5               | 8   | mA   |
| ILI              | Input Leakage<br>Current                                                                  | V <sub>IN</sub> = V <sub>CC</sub><br>or GND         | -1  | ±0.1 | 1   |     |                 |     | μA   |
| ILO              | Output Leakage<br>Current                                                                 | V <sub>OUT</sub> = V <sub>CC</sub><br>or GND        | -10 | ±5   | 10  |     |                 |     | μΑ   |

NOTES: 2. CMOS inputs: GND  $\pm$  0.3 V or V<sub>CC</sub>  $\pm$  0.3V.

3. CSI/A19 is high and the part is in a power-down configuration mode.

4. Add 2.0 mA/MHz for AC power component (power = AC + DC).

5. Ten (10) PAD product terms active. (Add 190  $\mu A$  per product term, typical, or 240  $\mu A$  per product term maximum.)

6. Forty (40) PAD product terms active.

\* Before 8/1/93.

\*\* After 8/1/93.

vs.

#### 3-volt single-chip microcontroller peripheral

Preliminary specification

PSD311L



The Normalized Supply Current vs. Supply Voltage graph shown above, provides a multiplier for any I<sub>SB</sub> or I<sub>CC</sub> value in the D.C. Characteristics table. As noted, it is normalized for a supply voltage of 3.3 volts. Since device characterization data shows very little supply current difference over speed, the multiplier includes all

frequencies of operation from standby to quiescent to full dynamic speed. To use, calculate the supply current at 3.3 volts for your operation configuration using the D.C. Characteristics table. Then multiply that value by the Supply Current Multiplier for the supply voltage actually being used.

# 3-volt single-chip microcontroller peripheral

PSD311L

| AC<br>Characteristics <sup>(8)</sup><br>(See Timing<br>Diagrams) |        | Parameter                                                                             | -25 |     | -30 |     |                      |      |
|------------------------------------------------------------------|--------|---------------------------------------------------------------------------------------|-----|-----|-----|-----|----------------------|------|
|                                                                  | Symbol |                                                                                       | Min | Max | Min | Max | CMiser = 1<br>Add:** | Unit |
| <i>viayians</i> j                                                | T1     | ALE or AS Pulse Width                                                                 | 75  |     | 80  |     |                      | ns   |
|                                                                  | T2     | Address Set-up Time                                                                   | 30  |     | 35  |     |                      | ns   |
|                                                                  | Т3     | Address Hold Time                                                                     | 30  |     | 35  |     | 0                    | ns   |
|                                                                  | T4     | Leading Edge of Read to Data Active                                                   | 0   |     | 0   |     | 0                    | ns   |
|                                                                  | T5     | ALE Valid to Data Valid                                                               |     | 250 |     | 300 | 25                   | ns   |
|                                                                  | T6     | Address Valid to Data Valid                                                           |     | 250 |     | 300 | 25                   | ns   |
|                                                                  | T7     | CSI Active to Data Valid                                                              |     | 275 |     | 325 | 30                   | ns   |
|                                                                  | Т8     | Leading Edge of Read<br>to Data Valid                                                 |     | 90  |     | 95  | 0                    | ns   |
|                                                                  | T9     | Read Data Hold Time                                                                   | 0   |     | 0   |     | 0                    | ns   |
|                                                                  | T10    | Trailing Edge of Read<br>to Data High-Z                                               |     | 50  |     | 55  | 0                    | ns   |
|                                                                  | T11    | Trailing Edge of ALE or AS to Leading Edge of Write                                   |     | 40  |     | 45  |                      | ns   |
|                                                                  | T12    | RD, E, PSEN, DS Pulse Width                                                           | 100 |     | 110 |     | 0                    | ns   |
|                                                                  | T12A   | WR Pulse Width                                                                        | 90  |     | 95  |     | 0                    | ns   |
|                                                                  | T13    | Trailing Edge of Write or Read to Leading Edge of ALE or AS                           | 0   |     | 0   |     | 0                    | ns   |
|                                                                  | T14    | Address Valid to Trailing<br>Edge of Write                                            | 250 |     | 300 |     | 0                    | ns   |
|                                                                  | T15    | CSI Active to Trailing Edge<br>of Write                                               | 275 |     | 375 |     | 0                    | ns   |
|                                                                  | T16    | Write Data Set-up Time                                                                | 60  |     | 65  |     | 0                    | ns   |
|                                                                  | T17    | Write Data Hold Time                                                                  | 25  |     | 30  |     | 0                    | ns   |
|                                                                  | T18    | Port to Data Out Valid<br>Propagation Delay                                           |     | 70  |     | 75  | 0                    | ns   |
|                                                                  | T19    | Port Input Hold Time                                                                  | 0   |     | 0   |     | 0                    | ns   |
|                                                                  | T20    | Trailing Edge of Write to Port<br>Output Valid                                        | 100 |     | 110 |     | 0                    | ns   |
|                                                                  | T21    | ADi or Control to CSOi Valid                                                          | 6   | 80  | 5   | 85  | 0                    | ns   |
|                                                                  | T22    | ADi or Control to CSOi Invalid                                                        | 4   | 80  | 4   | 85  | 0                    | ns   |
|                                                                  | T23    | Track Mode Address Propagation<br>Delay: CSADOUT1 Already True                        |     | 70  |     | 75  | 0                    | ns   |
|                                                                  | T23A   | Track Mode Address<br>Propagation Delay:<br>CSADOUT1 Becomes True<br>During ALE or AS |     | 100 |     | 110 | 0                    | ns   |

NOTE: 8. These AC Characteristics are for  $V_{CC} = 3.0 - 3.6V$ .

AC

## 3-volt single-chip microcontroller peripheral

PSD311L

| AC<br>Characteristics |        |                                                              | -2  | 25  | -3  | 80  |                      |      |
|-----------------------|--------|--------------------------------------------------------------|-----|-----|-----|-----|----------------------|------|
| (Cont.)               | Symbol | Parameter                                                    | Min | Max | Min | Max | CMiser = 1<br>Add:** | Unit |
|                       | T24    | Track Mode Trailing Edge of ALE<br>or AS to Address High-Z   |     | 60  |     | 65  | 0                    | ns   |
|                       | T25    | Track Mode Read Propagation<br>Delay                         |     | 70  |     | 75  | 0                    | ns   |
|                       | T26    | Track Mode Read Hold Time                                    | 10  | 70  | 10  | 75  |                      | ns   |
|                       | T27    | Track Mode Write Cycle,<br>Data Propagation Delay            |     | 60  |     | 65  | 0                    | ns   |
|                       | T28    | Track Mode Write Cycle,<br>Write to Data Propagation Delay   | 7   | 80  | 7   | 85  | 0                    | ns   |
|                       | T29    | Hold Time of Port A Valid<br>During Write CSOi Trailing Edge | 4   |     | 4   |     | 0                    | ns   |
|                       | T30    | CSI Active to CSOi Active                                    | 9   | 110 | 8   | 120 | 0                    | ns   |
|                       | T31    | CSI Inactive to CSOi Inactive                                | 9   | 110 | 8   | 120 | 0                    | ns   |
|                       | T32    | Direct PAD Input as Hold Time                                | 24  |     | 30  |     | . 0                  | ns   |
|                       | T33    | R/W Active to E or DS Start                                  | 60  |     | 65  |     | 0                    | ns   |
|                       | T34    | E or $\overline{\text{DS}}$ End to $\overline{\text{R/W}}$   | 60  |     | 65  |     | 0                    | ns   |
|                       | T35    | AS Inactive to E high                                        | 40  |     | 45  |     | 0                    | ns   |
|                       | T36    | Address to Leading Edge of Write                             | 50  |     | 60  |     | 0                    | ns   |

NOTES: 9. ADi = any address line.

10.  $\overline{\text{CSOi}}$  = any of the chip-select output signals coming through Port B ( $\overline{\text{CSO}}$ - $\overline{\text{CS7}}$ ) or through Port C (CS8-CS10).

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

12. Control signals RD/E/DS or WR or R/W.

\*\*After 8/1/1993.

#### Philips Semiconductors Microcontroller Peripherals

# 3-volt single-chip microcontroller peripheral

# PSD311L



## PSD311L





# PSD311L

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



### PSD311L



#### Philips Semiconductors Microcontroller Peripherals

# 3-volt single-chip microcontroller peripheral

# PSD311L



# Field-programmable microcontroller peripheral

# PSD311L



#### Philips Semiconductors Microcontroller Peripherals

# 3-volt single-chip microcontroller peripheral

## PSD311L



See referenced notes on page 216.

May, 1993

PSD311L

29

28



#### Figure 11. Port A as ADO – AD7 Timing (Track Mode), CRRWR = 1

23

*Notes for Timing Diagrams* 

CSOi (15,18)

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

23

- 14. Multiplexed inputs: any of the following inputs that are latched by the ALE (or AS): A0/AD0–A15/AD15, CSI/A19 as ALE dependent A19, ALE dependent PC0–PC2.
- <u>CSOi</u> = any of the chip-select output signals coming through Port B (<u>CS0–CS7</u>) or through Port C (<u>CS8–CS10</u>).
- 16. CSADOUT1, which internally enables the address transfer to Port A, should be derived only from direct PAD input signals, otherwise the address propagation delay is slowed down.
- 17. CSADIN and CSADOUT2, which internally enable the data-in or data-out transfers, respectively, can be derived from any combination of direct PAD inputs and multiplexed PAD inputs.
- 18. The write operation signals are included in the CSOi expression.
- Multiplexed PAD inputs: any of the following PAD inputs that are latched by the ALE (or AS) in the multiplexed modes: A11/AD11-A15/AD15, CSI/A19 as ALE dependent A19, ALE dependent PC0-PC2.

20. CSOi product terms can include any of the PAD input signals except for reset and CSI.

PSD311L

#### Pin Capacitance<sup>21</sup>

 $T_A=25\,^\circ C,\,f=1\,\,MHz$ 

| Symbol | Parameter                                                            | <b>Conditions</b>      | Typical <sup>22</sup> | Max | Unit |
|--------|----------------------------------------------------------------------|------------------------|-----------------------|-----|------|
| CIN    | Capacitance (for input pins only)                                    | V <sub>IN</sub> = 0 V  | 4                     | 6   | pF   |
| COUT   | Capacitance (for input/output pins)                                  | V <sub>OUT</sub> = 0 V | 8                     | 12  | pF   |
| CVPP   | Capacitance (for $\overline{WR}/V_{PP}$ or $R/\overline{W}/V_{PP}$ ) | $V_{PP} = 0 V$         | 18                    | 25  | pF   |

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

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

#### Erasure and Programming

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

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

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

.

PSD311L

Preliminary specification

| in<br>ssignments | Pin Name                  | 44-Pin<br>PLCC/CLCC<br>Package |
|------------------|---------------------------|--------------------------------|
|                  | PSEN                      | 1                              |
|                  | WR/V <sub>PP</sub> or R/W | 2                              |
|                  | RESET                     | 3                              |
|                  | PB7                       | 4                              |
|                  | PB6                       | 5                              |
|                  | PB5                       | 6                              |
|                  | PB4                       | 7                              |
|                  | PB3                       | 8                              |
|                  | PB2                       | 9                              |
|                  | PB1                       | 10                             |
|                  | PB0                       | 11                             |
|                  | GND                       | 12                             |
|                  | ALE or AS                 | 13                             |
|                  | PA7                       | 14                             |
|                  | PA6                       | 15                             |
|                  | PA5                       | 16                             |
|                  | PA4                       | 17                             |
|                  | PA3                       | 18                             |
|                  | PA2                       | 19                             |
|                  | PA1                       | 20                             |
|                  | PA0                       | 21                             |
|                  | RD/E                      | 22                             |
|                  | AD0/A0                    | 23                             |
|                  | AD1/A1                    | 24                             |
|                  | AD2/A2                    | 25                             |
|                  | AD3/A3                    | 26                             |
|                  | AD4/A4                    | 27                             |
|                  | AD5/A5                    | 28                             |
|                  | AD6/A6                    | 29                             |
|                  | AD7/A7                    | 30                             |
|                  | A8                        | 31                             |
|                  | A9                        | 32                             |
|                  | A10                       | 33                             |
|                  | GND<br>A11                | 34                             |
|                  |                           | 35                             |
|                  | A12                       | 36                             |
|                  | A13<br>A14                | 37                             |
|                  | A14<br>A15                | 38                             |
|                  | PC0                       | 39<br>40                       |
|                  | PC0<br>PC1                | 40<br>41                       |
|                  | PC1<br>PC2                | 41<br>42                       |
|                  | A19/CSI                   | 42<br>43                       |
|                  | V <sub>cc</sub>           | 43                             |
|                  | *CC                       | 44                             |

### Philips Semiconductors Microcontroller Peripherals

#### Preliminary specification

# 3-volt single-chip microcontroller peripheral

PSD311L



PSD311L

| Ordering<br>Information | Part Number  | Spd.<br>(ns) | Package<br>Type | Package<br>Drawing | Operating<br>Temperature<br>Range | Manufacturing<br>Procedure |
|-------------------------|--------------|--------------|-----------------|--------------------|-----------------------------------|----------------------------|
|                         | PSD311L25 A  | 250          | 44-pin PLDCC    | J2                 | Commercial                        | Standard                   |
|                         | PSD311L25 KA | 250          | 44-pin CLDCC    | L4                 | Commercial                        | Standard                   |
|                         | PSD311L30 A  | 300          | 44-pin PLDCC    | J2                 | Commercial                        | Standard                   |
|                         | PSD311L30 KA | 300          | 44-pin CLDCC    | L4                 | Commercial                        | Standard                   |

#### **Key Features**

- Single Chip Programmable Peripheral for Microcontroller-based Applications
- 3.0 to 5.5 Volt Operation
- 19 Individually Configurable I/O pins that can be used as:
- Microcontroller I/O port expansion
- Programmable Address Decoder (PAD) I/O
- Latched address output
- Open drain or CMOS
- Two Programmable Arrays (PAD A & PAD B)
- Total of 40 Product Terms and up to 18 Inputs and 24 Outputs
- Direct Address Decoding up to 1 Meg address space and up to 16 Meg with paging
- Logic replacement
- "No Glue" Microcontroller Chip-Set
- Built-in address latches for multiplexed address/data bus
- Non-multiplexed address/data bus mode
- Selectable 8 or 16 bit data bus width
- ALE and Reset polarity programmable
- Selectable modes for read and write control bus as RD/WR, R/W/E, or R/W/DS
- BHE pin for byte select in 16-bit mode
- PSEN pin for 8051 users
- Built-In Page Logic
- To Expand the Address Space of **Microcontrollers with Limited Address** Space Capabilities

221

- Up to 16 pages

- 512 Kbits of UV EPROM
- Configurable as 64K x 8 or as 32K x 16
- Divides into 8 equal mappable blocks for optimized mapping
- Block resolution is 8K x 8 or 4K x 16
- 250 ns EPROM access time, including input latches and PAD address decoding.
- 16 Kbit Static RAM
- Configurable as 2K x 8 or as 1K x 16
- 250 ns SRAM access time, including input latches and PAD address decoding
- Address/Data Track Mode
- Enables easy Interface to Shared Resources (e.g., Mail Box SRAM) with other Microcontrollers or a Host Processor
- CMiser-Bit
- Programmable option to further reduce power consumption
- Built-In Security
- Locks the PSD302L and PAD Decoding Configuration
- Available in a Choice of Packages
- 44 Pin PLDCC and CLDCC
- Simple Menu-Driven Software: Configure the PSD302L on an IBM PC
- Pin and Functionally Compatible with the PSD3XX and PSD3XXL Series



### PSD302L

Preliminary specification

Absolute Maximum Ratings<sup>1</sup>

# 3-volt single-chip microcontroller peripheral

### PSD302L

| Symbol           | Parameter                     | Condition           | Min   | Max   | Unit |
|------------------|-------------------------------|---------------------|-------|-------|------|
| T <sub>STG</sub> | Storage Temperature           | CERAMIC             | - 65  | + 150 | °C   |
| STG              | Slorage remperature           | PLASTIC             | - 65  | + 125 | °C   |
| T <sub>STG</sub> | Storage Temperature           |                     | - 65  | + 150 | °C   |
|                  | Voltage on any Pin            | With Respect to GND | - 0.6 | + 7   | V    |
| V <sub>PP</sub>  | Programming<br>Supply Voltage | With Respect to GND | - 0.6 | + 14  | v    |
| V <sub>cc</sub>  | Supply Voltage                | With Respect to GND | - 0.6 | + 7   | V    |
|                  | ESD Protection                |                     | [     | >2000 | V    |

**NOTE:** 1. Stresses above those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to Absolute Maximum Rating conditions for extended periods of time may affect device reliability.

| Operating<br>Range | Range      | Temperature   | V <sub>CC</sub> | ] |
|--------------------|------------|---------------|-----------------|---|
| nanyt              | Commercial | 0° C to +70°C | 3.0 V to 5.5 V  | l |

| Recommended             | Symbol          | Parameter                | Conditions                                 | Min                 | Тур | Max                    | Unit |
|-------------------------|-----------------|--------------------------|--------------------------------------------|---------------------|-----|------------------------|------|
| Operating<br>Conditions | V <sub>cc</sub> | Supply Voltage           | All Speeds                                 | 3.0                 | 3.3 | 5.5                    | V    |
| oonunnons               | VIH             | High-level Input Voltage | $V_{CC} = 3.0 \text{ V to } 5.5 \text{ V}$ | 0.7 V <sub>CC</sub> |     | $V_{CC} + 0.5$         | V    |
|                         | VIL             | Low-level Input Voltage  | V <sub>CC</sub> = 3.0 V to 5.5 V           | - 0.5               |     | 0.2 V <sub>CC</sub> *  | V    |
|                         | *12             |                          |                                            | 0.0                 |     | 0.3 V <sub>CC</sub> ** | V    |

\* Before 8/1/1993.

\*\*After 8/1/1993.

DC

**Characteristics** 

# 3-volt single-chip microcontroller peripheral

PSD302L

|                  |                                                    |                                                     |     |      |     |     | Miser<br>Ibtrac | -   |      |
|------------------|----------------------------------------------------|-----------------------------------------------------|-----|------|-----|-----|-----------------|-----|------|
| Symbol           | Parameter                                          | Conditions                                          | Min | Тур  | Max | Min | Тур             | Max | Unit |
| V <sub>OL</sub>  | Output Low                                         | I <sub>OL</sub> = 20 μA<br>V <sub>CC</sub> = 3.0 V  |     | 0.01 | 0.1 |     |                 |     | v    |
| .01              | Voltage                                            | l <sub>OL</sub> = 4 mA<br>V <sub>CC</sub> = 3.0 V   |     | 0.15 | 0.4 |     |                 |     | v    |
| V <sub>OH</sub>  | Output High                                        | l <sub>OH</sub> = -20 μA<br>V <sub>CC</sub> = 3.0 V | 2.9 | 2.99 |     |     |                 |     | v    |
| · On             | Voltage                                            | l <sub>OH</sub> = –1 mA<br>V <sub>CC</sub> = 3.0 V  | 2.4 | 2.6  |     |     |                 |     | v    |
|                  | V <sub>CC</sub> Standby<br>Current (CMOS)          | V <sub>CC</sub> = 3.3 V                             |     | 10*  | 25* |     |                 |     |      |
| I <sub>SB1</sub> | (Notes 2 and 3)                                    | v <sub>CC</sub> = 3.3 v                             |     | 1**  | 5** |     |                 |     | μA   |
| 1                | Active Current<br>(CMOS) (No<br>Internal Memory    | V <sub>CC</sub> = 3.3 V<br>(Note 5)                 |     | 6    | 12  |     | 3.0             | 5   | mA   |
| I <sub>CC1</sub> | Block Selected)<br>(Notes 2 and 5)                 | V <sub>CC</sub> = 3.3 V<br>(Note 6)                 |     | 10   | 20  |     | 3.0             | 5   | mA   |
| I <sub>CC2</sub> | Active Current<br>(CMOS) (EPROM<br>Block Selected) | V <sub>CC</sub> = 3.3 V<br>(Notes 5<br>and 7)       |     | 6    | 12  |     | 0               | 0   | mA   |
|                  | (Notes 2 and 5)                                    | V <sub>CC</sub> = 3.3 V<br>(Note 6<br>and 7)        |     | 10   | 20  |     | 0               | 0   | mA   |
| I <sub>CC3</sub> | Active Current<br>(CMOS) (SRAM                     | V <sub>CC</sub> = 3.3 V<br>(Note 5<br>and 7)        |     | 20   | 33  |     | 3               | 5   | mA   |
| -003             | Block Selected)<br>(Notes 2 and 5)                 | V <sub>CC</sub> = 3.3 V<br>(Notes 6<br>and 7)       |     | 24   | 40  |     | 3               | 5   | mA   |
| ILI              | Input Leakage<br>Current                           | V <sub>IN</sub> = V <sub>CC</sub><br>or GND         | -1  | ±0.1 | 1   |     |                 |     | μΑ   |
| ILO              | Output Leakage<br>Current                          | V <sub>OUT</sub> = V <sub>CC</sub><br>or GND        | -10 | ±5   | 10  |     |                 |     | μA   |

NOTES: 2. CMOS inputs: GND  $\pm$  0.3 V or V<sub>CC</sub>  $\pm$  0.3V.

3. CSI/A19 is high and the part is in a power-down configuration mode.

- 4. Add 2.0 mA/MHz for AC power component (power = AC + DC).
- 5. Ten (10) PAD product terms active. (Add 190  $\mu A$  per product term, typical, or 240  $\mu A$  per product term maximum.)

6. Forty (40) PAD product terms active.

7. In 8-bit mode, an additional 3 mA Max. can be saved under CMiser.

\* Before 8/1/1993.

\*\* After 8/1/1993.

PSD302L



The Normalized Supply Current vs. Supply Voltage graph shown above, provides a multiplier for any  $I_{SB}$  or  $I_{CC}$  value in the D.C. Characteristics table. As noted, it is normalized for a supply voltage of 3.3 volts. Since device characterization data shows very little supply current difference over speed, the multiplier includes all frequencies of operation from standby to quiescent to full dynamic speed. To use, calculate the supply current at 3.3 volts for your operation configuration using the D.C. Characteristics table. Then multiply that value by the Supply Current Multiplier for the supply voltage actually being used.

# 3-volt single-chip microcontroller peripheral

PSD302L

| AC<br>Characteristics <sup>(8)</sup> |        |                                                                                       | -2  | 25  | -3  | 80  |                    |      |
|--------------------------------------|--------|---------------------------------------------------------------------------------------|-----|-----|-----|-----|--------------------|------|
| (See Timing<br>Diagrams)             | Symbol | Parameter                                                                             | Min | Max | Min | Max | CMiser = 1<br>Add: | Unit |
| Diagranisj                           | T1     | ALE or AS Pulse Width                                                                 | 75  |     | 80  |     |                    | ns   |
|                                      | T2     | Address Set-up Time                                                                   | 30  |     | 35  |     |                    | ns   |
|                                      | Т3     | Address Hold Time                                                                     | 30  |     | 35  |     | 0.                 | ns   |
|                                      | T4     | Leading Edge of Read to Data Active                                                   | 0   |     | 0   |     | 0                  | ns   |
|                                      | T5     | ALE Valid to Data Valid                                                               |     | 250 |     | 300 | 25                 | ns   |
|                                      | Т6     | Address Valid to Data Valid                                                           |     | 250 |     | 300 | 25                 | ns   |
|                                      | T7     | CSI Active to Data Valid                                                              |     | 275 |     | 325 | 30                 | ns   |
|                                      | Т8     | Leading Edge of Read<br>to Data Valid                                                 |     | 90  |     | 95  | 0                  | ns   |
|                                      | Т9     | Read Data Hold Time                                                                   | 0   |     | 0   |     | 0                  | ns   |
|                                      | T10    | Trailing Edge of Read<br>to Data High-Z                                               |     | 50  |     | 55  | 0                  | ns   |
|                                      | T11    | Trailing Edge of ALE or AS to Leading Edge of Write                                   |     | 40  |     | 45  |                    | ns   |
|                                      | T12    | RD, E, PSEN, DS Pulse Width                                                           | 100 |     | 110 |     | 0                  | ns   |
|                                      | T12A   | WR Pulse Width                                                                        | 90  |     | 95  |     | 0                  | ns   |
|                                      | T13    | Trailing Edge of Write or Read to Leading Edge of ALE or AS                           | 0   |     | 0   |     | 0                  | ns   |
|                                      | T14    | Address Valid to Trailing<br>Edge of Write                                            | 250 |     | 300 |     | 0                  | ns   |
|                                      | T15    | CSI Active to Trailing Edge<br>of Write                                               | 275 |     | 375 |     | 0                  | ns   |
|                                      | T16    | Write Data Set-up Time                                                                | 60  |     | 65  |     | 0                  | ns   |
|                                      | T17    | Write Data Hold Time                                                                  | 25  |     | 30  |     | 0                  | ns   |
|                                      | T18    | Port to Data Out Valid<br>Propagation Delay                                           |     | 70  |     | 75  | 0                  | ns   |
|                                      | T19    | Port Input Hold Time                                                                  | 0   |     | 0   |     | 0                  | ns   |
|                                      | T20    | Trailing Edge of Write to Port<br>Output Valid                                        | 100 |     | 110 |     | 0                  | ns   |
|                                      | T21    | ADi or Control to CSOi Valid                                                          | 6   | 80  | 5   | 85  | 0                  | ns   |
|                                      | T22    | ADi or Control to CSOi Invalid                                                        | 4   | 80  | 4   | 85  | 0                  | ns   |
|                                      | T23    | Track Mode Address Propagation<br>Delay: CSADOUT1 Already True                        |     | 70  |     | 75  | 0                  | ns   |
|                                      | T23A   | Track Mode Address<br>Propagation Delay:<br>CSADOUT1 Becomes True<br>During ALE or AS |     | 100 |     | 110 | 0                  | ns   |

NOTE: 8. These AC Characteristics are for  $V_{CC} = 3.0 - 3.6V$ .

AC

(Cont.)

**Characteristics** 

## 3-volt single-chip microcontroller peripheral

PSD302L

|        |                                                              |     | -25 |     | 80  |                    |      |
|--------|--------------------------------------------------------------|-----|-----|-----|-----|--------------------|------|
| Symbol | Parameter                                                    | Min | Max | Min | Max | CMiser = 1<br>Add: | Unit |
| T24    | Track Mode Trailing Edge of ALE<br>or AS to Address High-Z   |     | 60  |     | 65  | 0                  | ns   |
| T25    | Track Mode Read Propagation<br>Delay                         |     | 70  |     | 75  | 0                  | ns   |
| T26    | Track Mode Read Hold Time                                    | 10  | 70  | 10  | 75  |                    | ns   |
| T27    | Track Mode Write Cycle,<br>Data Propagation Delay            |     | 60  |     | 65  | 0                  | ns   |
| T28    | Track Mode Write Cycle,<br>Write to Data Propagation Delay   | 7   | 80  | 7   | 85  | 0                  | ns   |
| T29    | Hold Time of Port A Valid<br>During Write CSOi Trailing Edge | 4   |     | 4   |     | 0                  | ns   |
| T30    | CSI Active to CSOi Active                                    | 9   | 110 | 8   | 120 | 0                  | ns   |
| T31    | CSI Inactive to CSOi Inactive                                | 9   | 110 | 8   | 120 | 0                  | ns   |
| T32    | Direct PAD Input as Hold Time                                | 24  |     | 30  |     | 0                  | ns   |
| Т33    | $R/\overline{W}$ Active to E or $\overline{DS}$ Start        | 60  |     | 65  |     | 0                  | ns   |
| T34    | E or DS End to R/W                                           | 60  |     | 65  |     | 0                  | ns   |
| T35    | AS Inactive to E high                                        | 40  |     | 45  |     | 0                  | ns   |
| T36    | Address to Leading Edge of Write                             | 50  |     | 60  |     | 0                  | ns   |

NOTES: 9. ADi = any address line.

 CSOi = any of the chip-select output signals coming through Port B (CS0–CS7) or through Port C (CS8–CS10).

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

12. Control signals RD/E/DS or WR or R/W.

#### Philips Semiconductors Microcontroller Peripherals

### Preliminary specification

# 3-volt single-chip microcontroller peripheral



## PSD302L





### PSD302L





ŝ

# 3-volt single-chip microcontroller peripheral

PSD302L



#### *Timing of 16-Bit Multiplexed Address/Data Bus, CRRWR = 0*

Figure 7.

### PSD302L





PSD302L

## 3-volt single-chip microcontroller peripheral



See referenced notes on page 238.

232





See referenced notes on page 238.

May, 1993

5

PSD302L

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



### PSD302L





### PSD302L



PSD302L

### Figure 15. Port A as ADO – AD7 Timing (Track Mode), CRRWR = 1



#### Notes for Timing Diagrams

- Direct PAD input = any of the following direct PAD input lines: CSI/A19 as transparent A19, RD/E/DS, WR or R/W, transparent PC0–PC2, ALE in non-multiplexed modes.
- Multiplexed inputs: any of the following inputs that are latched by the ALE (or AS): A0/AD0–A15/AD15, CSI/A19 as ALE dependent A19, ALE dependent PC0–PC2.
- CSOt = any of the chip-select output signals coming through Port B (CS0–CS7) or through Port C (CS8–CS10).
- 16. CSADOUT1, which internally enables the address transfer to Port A, should be derived only from direct PAD input signals, otherwise the address propagation delay is slowed down.
- 17. CSADIN and CSADOUT2, which internally enable the data-in or data-out transfers, respectively, can be derived from any combination of direct PAD inputs and multiplexed PAD inputs.
- 18. The write operation signals are included in the  $\overline{\text{CSOi}}$  expression.
- Multiplexed PAD inputs: any of the following PAD inputs that are latched by the ALE (or AS) in the multiplexed modes: A11/AD11–A15/AD15, CSI/A19 as ALE dependent A19, ALE dependent PC0–PC2.

20. CSOi product terms can include any of the PAD input signals except for reset and CSI.

PSD302L

| <b>D</b> I      |        |
|-----------------|--------|
| Pin             |        |
|                 |        |
| Concolt         | 080021 |
| <b>Capacita</b> | ance   |
|                 |        |

#### $T_A = 25 \circ C, f = 1 MHz$

| Symbol | Parameter                           | <b>Conditions</b>      | Typical <sup>22</sup> | Max | Unit |
|--------|-------------------------------------|------------------------|-----------------------|-----|------|
| CIN    | Capacitance (for input pins only)   | V <sub>IN</sub> = 0 V  | 4                     | 6   | pF   |
| Cout   | Capacitance (for input/output pins) | V <sub>OUT</sub> = 0 V | 8                     | 12  | pF   |
| CVPP   | Capacitance (for WR/VPP or R/W/VPP) | V <sub>PP</sub> = 0 V  | 18                    | 25  | pF   |

**NOTES:** 21. This parameter is only sampled and is not 100% tested. 22. Typical values are for  $T_A = 25^{\circ}C$  and nominal supply voltages.

#### Erasure and Programming

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

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

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

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



| Ordering<br>Information | Part Number  | Spd.<br>(ns) | Package<br>Type | Package<br>Drawing | Operating<br>Temperature<br>Range | Manufacturing<br>Procedure |
|-------------------------|--------------|--------------|-----------------|--------------------|-----------------------------------|----------------------------|
|                         | PSD302L25 A  | 250          | 44-pin PLDCC    | J2                 | Commercial                        | Standard                   |
|                         | PSD302L25 KA | 250          | 44-pin CLDCC    | L4                 | Commercial                        | Standard                   |
|                         | PSD302L30 A  | 300          | 44-pin PLDCC    | J2                 | Commercial                        | Standard                   |
|                         | PSD302L30 KA | 300          | 44-pin CLDCC    | L4                 | Commercial                        | Standard                   |

### Key Features

- Single Chip Programmable Peripheral for Microcontroller-based Applications
- 3.0 to 5.5 Volt Operation
- 19 Individually Configurable I/O pins that can be used as:
- Microcontroller I/O port expansion
- Programmable Address Decoder (PAD) I/O
- Latched address output
- Open drain or CMOS
- Two Programmable Arrays (PAD A & PAD B)
- Total of 40 Product Terms and up to 18 Inputs and 24 Outputs
- Direct Address Decoding up to 1 Meg address space and up to 16 Meg with paging
- Logic replacement
- □ "No Glue" Microcontroller Chip-Set
- Built-in address latches for multiplexed address/data bus
- Non-multiplexed address/data bus mode
- 8-bit data bus width
- ALE and Reset polarity programmable
- Selectable modes for read and write control bus as RD/WR, R/W/E, or R/W/DS
- PSEN pin for 8051 users
- Built-In Page Logic
- To Expand the Address Space of Microcontrollers with Limited Address Space Capabilities
- Up to 16 pages

- 512 Kbits of UV EPROM
- Configurable as 64K x 8
- --- Divides into 8 equal mappable blocks for optimized mapping
- Block resolution is 8K x 8
- 250 ns EPROM access time, including input latches and PAD address decoding.
- 16 Kbit Static RAM
- Configurable as 2K x 8 or as 1K x 16
- 250 ns SRAM access time, including input latches and PAD address decoding
- Address/Data Track Mode
- --- Enables easy Interface to Shared Resources (e.g., Mail Box SRAM) with other Microcontrollers or a Host Processor
- CMiser-Bit
- Programmable option to further reduce power consumption
- Built-In Security
- Locks the PSD312L and PAD Decoding Configuration
- Available in a Choice of Packages
- 44 Pin PLDCC and CLDCC
- Simple Menu-Driven Software: Configure the PSD312L on an IBM PC
- □ Pin and Functionally Compatible with the PSD3XX and PSD3XXL Series.

### PSD312L

# PSD312L

| bsolute                         | Symbol           | Parameter                     | Condition           | Min   | Max   | Unit |
|---------------------------------|------------------|-------------------------------|---------------------|-------|-------|------|
| Maximum<br>Potlago <sup>1</sup> | Т                | Storage Temperature           | CERAMIC             | - 65  | + 150 | °C   |
| Ratings <sup>1</sup>            | T <sub>STG</sub> | ISTG Storage remperature      | PLASTIC             | - 65  | + 125 | °C   |
|                                 | T <sub>STG</sub> | Storage Temperature           |                     | - 65  | + 150 | °C   |
|                                 |                  | Voltage on any Pin            | With Respect to GND | - 0.6 | + 7   | V    |
|                                 | V <sub>PP</sub>  | Programming<br>Supply Voltage | With Respect to GND | - 0.6 | + 14  | v    |
|                                 | Vcc              | Supply Voltage                | With Respect to GND | - 0.6 | + 7   | v    |
|                                 |                  | ESD Protection                |                     |       | >2000 | V    |

**NOTE:** 1. Stresses above those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to Absolute Maximum Rating conditions for extended periods of time may affect device reliability.

| Operating<br>Range | Range      | Temperature   | V <sub>CC</sub> |
|--------------------|------------|---------------|-----------------|
| nanyc              | Commercial | 0° C to +70°C | 3.0 V to 5.5 V  |

#### Recommended Syn Operating Conditions

| Symbol              | Parameter                | Conditions                                 | Min                 | Тур | Max                    | Unit |
|---------------------|--------------------------|--------------------------------------------|---------------------|-----|------------------------|------|
| Vcc                 | Supply Voltage           | All Speeds                                 | 3.0                 | 3.3 | 5.5                    | ٧    |
| VIH                 | High-level Input Voltage | $V_{CC} = 3.0 \text{ V to } 5.5 \text{ V}$ | 0.7 V <sub>CC</sub> |     | V <sub>CC</sub> + 0.5  | ۷    |
| V <sub>IL</sub> · L |                          |                                            | 0.5                 |     | 0.2 V <sub>CC</sub> *  | ۷    |
|                     | Low-level Input Voltage  | V <sub>CC</sub> = 3.0 V to 5.5 V           | - 0.5               |     | 0.3 V <sub>CC</sub> ** | V    |

\* Before 8/1/1993.

\*\* After 8/1/1993.

DC

**Characteristics** 

# 3-volt single-chip microcontroller peripheral

PSD312L

|                                    |                                                       |                                                     |     |      | _   | Miser<br>Ibtrac |     |     |      |
|------------------------------------|-------------------------------------------------------|-----------------------------------------------------|-----|------|-----|-----------------|-----|-----|------|
| Symbol                             | Parameter                                             | Conditions                                          | Min | Тур  | Max | Min             | Тур | Max | Unit |
| V <sub>OL</sub>                    | Output Low                                            | l <sub>OL</sub> = 20 μA<br>V <sub>CC</sub> = 3.0 V  |     | 0.01 | 0.1 |                 |     |     | v    |
| VOL                                | Voltage                                               | I <sub>OL</sub> = 4 mA<br>V <sub>CC</sub> = 3.0 V   |     | 0.15 | 0.4 |                 |     |     | v    |
| V <sub>OH</sub>                    | Output High                                           | I <sub>OH</sub> = -20 μA<br>V <sub>CC</sub> = 3.0 V | 2.9 | 2.99 |     |                 |     |     | v    |
| · On                               | Voltage                                               | I <sub>OH</sub> = -1 mA<br>V <sub>CC</sub> = 3.0 V  | 2.4 | 2.6  |     |                 |     |     | v    |
| lan.                               | V <sub>CC</sub> Standby<br>Current (CMOS)             | V <sub>CC</sub> = 3.3 V                             |     | 10*  | 25* |                 |     |     |      |
| I <sub>SB1</sub>                   | (Notes 2 and 3)                                       | VCC = 0.0 V                                         |     | 1**  | 5** |                 |     |     | μA   |
| Active Current<br>(CMOS) (No       |                                                       | V <sub>CC</sub> = 3.3 V<br>(Note 5)                 |     | 6    | 12  |                 | 3.0 | 5   | mA   |
| I <sub>CC1</sub>                   | Internal Memory<br>Block Selected)<br>(Notes 2 and 5) | V <sub>CC</sub> = 3.3 V<br>(Note 6)                 |     | 10   | 20  |                 | 3.0 | 5   | mA   |
| 1                                  | Active Current<br>(CMOS) (EPROM                       | V <sub>CC</sub> = 3.3 V<br>(Note 5)                 |     | 6    | 12  |                 | 2   | 3   | mA   |
| I <sub>CC2</sub>                   | Block Selected)<br>(Notes 2 and 5)                    | V <sub>CC</sub> = 3.3 V<br>(Note 6)                 |     | 10   | 20  |                 | 2   | 3   | mA   |
| I <sub>CC3</sub>                   | Active Current<br>(CMOS) (SRAM                        | V <sub>CC</sub> = 3.3 V<br>(Note 5)                 |     | 20   | 33  |                 | 5   | 8   | mA   |
| Block Selected)<br>(Notes 2 and 5) |                                                       | V <sub>CC</sub> = 3.3 V<br>(Note 6)                 |     | 24   | 40  |                 | 5   | 8   | mA   |
| lu                                 | Input Leakage<br>Current                              | V <sub>IN</sub> = V <sub>CC</sub><br>or GND         | -1  | ±0.1 | 1   |                 |     |     | μΑ   |
| ILO                                | Output Leakage<br>Current                             | V <sub>OUT</sub> = V <sub>CC</sub><br>or GND        | -10 | ±5   | 10  |                 |     |     | μА   |

NOTES: 2. CMOS inputs: GND  $\pm$  0.3 V or V<sub>CC</sub>  $\pm$  0.3V.

3. CSI/A19 is high and the part is in a power-down configuration mode.

4. Add 2.0 mA/MHz for AC power component (power = AC + DC).

5. Ten (10) PAD product terms active. (Add 190 μA per product term, typical, or 240 μA per product term maximum.)

6. Forty (40) PAD product terms active.

\* Before 8/1/1993.

\*\* After 8/1/1993.

PSD312L



The Normalized Supply Current vs. Supply Voltage graph shown above, provides a multiplier for any  $I_{SB}$  or  $I_{CC}$  value in the D.C. Characteristics table. As noted, it is normalized for a supply voltage of 3.3 volts. Since device characterization data shows very little supply current difference over speed, the multiplier includes all frequencies of operation from standby to quiescent to full dynamic speed. To use, calculate the supply current at 3.3 volts for your operation configuration using the D.C. Characteristics table. Then multiply that value by the Supply Current Multiplier for the supply voltage actually being used.

# 3-volt single-chip microcontroller peripheral

PSD312L

| C<br>haracterístics <sup>(8)</sup> |        |                                                                                       | -2  | 25  | -3  | 80  | Ollison 1          |      |
|------------------------------------|--------|---------------------------------------------------------------------------------------|-----|-----|-----|-----|--------------------|------|
| See Timing<br>Nagrams)             | Symbol | Parameter                                                                             | Min | Max | Min | Max | CMiser = 1<br>Add: | Unit |
| iayi allisj                        | T1     | ALE or AS Pulse Width                                                                 | 75  |     | 80  |     |                    | ns   |
|                                    | T2     | Address Set-up Time                                                                   | 30  |     | 35  |     |                    | ns   |
|                                    | T3     | Address Hold Time                                                                     | 30  |     | 35  |     | 0                  | ns   |
|                                    | T4     | Leading Edge of Read to Data Active                                                   | 0   |     | 0   |     | 0                  | ns   |
|                                    | T5     | ALE Valid to Data Valid                                                               |     | 250 |     | 300 | 25                 | ns   |
|                                    | Т6     | Address Valid to Data Valid                                                           |     | 250 |     | 300 | 25                 | ns   |
|                                    | 17     | CSI Active to Data Valid                                                              |     | 275 |     | 325 | 30                 | ns   |
|                                    | Т8     | Leading Edge of Read<br>to Data Valid                                                 |     | 90  |     | 95  | 0                  | ns   |
|                                    | Т9     | Read Data Hold Time                                                                   | 0   |     | 0   |     | 0                  | ns   |
|                                    | T10    | Trailing Edge of Read<br>to Data High-Z                                               |     | 50  |     | 55  | 0                  | ns   |
|                                    | T11    | Trailing Edge of ALE or AS to Leading Edge of Write                                   |     | 40  |     | 45  |                    | ns   |
|                                    | T12    | RD, E, PSEN, DS Pulse Width                                                           | 100 |     | 110 |     | 0                  | ns   |
|                                    | T12A   | WR Pulse Width                                                                        | 90  |     | 95  |     | 0                  | ns   |
|                                    | T13    | Trailing Edge of Write or Read to Leading Edge of ALE or AS                           | 0   |     | 0   |     | 0                  | ns   |
|                                    | T14    | Address Valid to Trailing<br>Edge of Write                                            | 250 |     | 300 |     | 0                  | ns   |
|                                    | T15    | CSI Active to Trailing Edge<br>of Write                                               | 275 |     | 375 |     | 0                  | ns   |
|                                    | T16    | Write Data Set-up Time                                                                | 60  |     | 65  |     | 0                  | ns   |
|                                    | T17    | Write Data Hold Time                                                                  | 25  |     | 30  |     | 0                  | ns   |
|                                    | T18    | Port to Data Out Valid<br>Propagation Delay                                           |     | 70  |     | ۰75 | 0                  | ns   |
|                                    | T19    | Port Input Hold Time                                                                  | 0   |     | 0   |     | 0                  | ns   |
|                                    | T20    | Trailing Edge of Write to Port<br>Output Valid                                        | 100 |     | 110 |     | 0                  | ns   |
|                                    | T21    | ADi or Control to CSOi Valid                                                          | 6   | 80  | 5   | 85  | 0                  | ns   |
|                                    | T22    | ADi or Control to CSOi Invalid                                                        | 4   | 80  | 4   | 85  | 0                  | ns   |
|                                    | T23    | Track Mode Address Propagation<br>Delay: CSADOUT1 Already True                        |     | 70  |     | 75  | 0                  | ns   |
|                                    | T23A   | Track Mode Address<br>Propagation Delay:<br>CSADOUT1 Becomes True<br>During ALE or AS |     | 100 |     | 110 | 0                  | ns   |

**NOTE:** 8. These AC Characteristics are for VCC = 3.0 - 3.6V.

# 3-volt single-chip microcontroller peripheral

PSD312L

| AC<br>Characteristics |                                 |                                                              | -2  | 5   | -3  | 80  |                    |      |
|-----------------------|---------------------------------|--------------------------------------------------------------|-----|-----|-----|-----|--------------------|------|
| (Cont.)               | Symbol                          | Parameter                                                    | Min | Max | Min | Max | CMiser = 1<br>Add: | Unit |
|                       | T24                             | Track Mode Trailing Edge of ALE<br>or AS to Address High-Z   |     | 60  |     | 65  | 0                  | ns   |
|                       | T25                             | Track Mode Read Propagation<br>Delay                         |     | 70  |     | 75  | 0                  | ns   |
|                       | T26                             | Track Mode Read Hold Time                                    | 10  | 70  | 10  | 75  |                    | ns   |
| T27                   |                                 | Track Mode Write Cycle,<br>Data Propagation Delay            |     | 60  |     | 65  | 0                  | ns   |
|                       | T28                             | Track Mode Write Cycle,<br>Write to Data Propagation Delay   | 7   | 80  | 7   | 85  | 0                  | ns   |
|                       | T29                             | Hold Time of Port A Valid<br>During Write CSOi Trailing Edge | 4   |     | 4   |     | 0                  | ns   |
|                       | T30                             | CSI Active to CSOi Active                                    | 9   | 110 | 8   | 120 | 0                  | ns   |
|                       | T31                             | CSI Inactive to CSOi Inactive                                | 9   | 110 | 8   | 120 | 0                  | ns   |
|                       | T32                             | Direct PAD Input as Hold Time                                | 24  |     | 30  |     | 0                  | ns   |
|                       | T33 R/W Active to E or DS Start |                                                              | 60  |     | 65  |     | 0                  | ns   |
|                       | T34                             | E or DS End to R/W                                           | 60  |     | 65  |     | 0                  | ns   |
|                       | T35                             | AS Inactive to E high                                        | 40  |     | 45  |     | 0                  | ns   |
|                       | T36                             | Address to Leading Edge of Write                             | 50  |     | 60  |     | 0                  | ns   |

NOTES: 9. ADi = any address line.

CSOi = any of the chip-select output signals coming through Port B (CS0–CS7) or through Port C (CS8–CS10).

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

12. Control signals RD/E/DS or WR or R/W.



# PSD312L

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



# PSD312L

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



# PSD312L



### PSD312L





# PSD312L





PSD312L



### Figure 11. Port A as ADO – AD7 Timing (Track Mode), CRRWR = 1

*Notes for Timing Diagrams* 

- 13. <u>Direct PAD input = any of the following direct PAD input lines: CSI/A19 as transparent A19,</u> RD/E/DS, WR or R/W, transparent PC0–PC2, ALE in non-multiplexed modes.
- 14. Multiplexed inputs: any of the following inputs that are latched by the ALE (or AS): A0/AD0–A15/AD15, CSI/A19 as ALE dependent A19, ALE dependent PC0–PC2.
- 15. CSOi = any of the chip-select output signals coming through Port B (CS0–CS7) or through Port C (CS8–CS10).
- 16. CSADOUT1, which internally enables the address transfer to Port A, should be derived only from direct PAD input signals, otherwise the address propagation delay is slowed down.
- 17. CSADIN and CSADOUT2, which internally enable the data-in or data-out transfers, respectively, can be derived from any combination of direct PAD inputs and multiplexed PAD inputs.
- 18. The write operation signals are included in the CSOi expression.
- Multiplexed PAD inputs: any of the following PAD inputs that are latched by the ALE (or AS) in the multiplexed modes: A11/AD11-A15/AD15, CSI/A19 as ALE dependent A19, ALE dependent PC0-PC2.

20. CSOi product terms can include any of the PAD input signals except for reset and CSI.

### PSD312L

Pin Capacitance<sup>21</sup>

#### $T_{A} = 25 \circ C$ , f = 1 MHz

| Symbol | Parameter                           | <b>Conditions</b>      | Typical <sup>22</sup> | Max | Unit |
|--------|-------------------------------------|------------------------|-----------------------|-----|------|
| CiN    | Capacitance (for input pins only)   | V <sub>IN</sub> = 0 V  | 4                     | 6   | pF   |
| Cout   | Capacitance (for input/output pins) | V <sub>OUT</sub> = 0 V | 8                     | 12  | pF   |
| CVPP   | Capacitance (for WR/VPP or R/W/VPP) | V <sub>PP</sub> = 0 V  | 18                    | 25  | pF   |

**NOTES:** 21. This parameter is only sampled and is not 100% tested. 22. Typical values are for T<sub>A</sub> = 25°C and nominal supply voltages.

#### Erasure and Programming

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

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

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

## Preliminary specification

# 3-volt single-chip microcontroller peripheral

| Pin<br>Assignments | Pin Name                  | 44-Pin<br>PLCC/CLCC<br>Package |
|--------------------|---------------------------|--------------------------------|
|                    | PSEN                      | 1                              |
|                    | WR/V <sub>PP</sub> or R/W | 2                              |
|                    | RESET                     | 3                              |
|                    | PB7                       | 4                              |
|                    | PB6                       | 5                              |
|                    | PB5                       | 6                              |
|                    | PB4                       | 7                              |
|                    | PB3                       | 8                              |
|                    | PB2                       | 9                              |
|                    | PB1                       | 10                             |
|                    | PB0                       | 11                             |
|                    | GND                       | 12                             |
|                    | ALE or AS                 | 13                             |
|                    | PA7                       | 14                             |
|                    | PA6                       | 15                             |
|                    | PA5                       | 16                             |
|                    | PA4                       | 17                             |
|                    | PA3                       | 18                             |
| `                  | PA2                       | 19                             |
|                    | PA1                       | 20                             |
|                    | PAO                       | 21                             |
|                    | RD/E/DS                   | 22                             |
|                    | AD0/A0                    | 23                             |
|                    | AD1/A1                    | 24                             |
|                    | AD2/A2                    | 25                             |
|                    | AD3/A3                    | 26                             |
|                    | AD4/A4                    | 27                             |
|                    | AD5/A5                    | 28                             |
|                    | AD6/A6                    | 29                             |
|                    | AD7/A7                    | 30                             |
|                    | A8                        | 31                             |
|                    | A9                        | 32                             |
|                    | A10                       | 33                             |
|                    | GND                       | 34                             |
|                    | A11                       | 35                             |
|                    | A12                       | 36                             |
|                    | A13                       | 37                             |
|                    | A14                       | 38                             |
|                    | A15                       | 39                             |
|                    | PC0                       | 40                             |
|                    | PC1                       | 41                             |
|                    | PC2                       | 42                             |
|                    | A19/CSI                   | 43                             |
|                    | V <sub>cc</sub>           | 44                             |



| Ordering<br>Information | Part Number  | Spd.<br>(ns) | Package<br>Type | Package<br>Drawing | Operating<br>Temperature<br>Range | Manufacturing<br>Procedure |
|-------------------------|--------------|--------------|-----------------|--------------------|-----------------------------------|----------------------------|
|                         | PSD312L25 A  | 250          | 44-pin PLCC     | J2                 | Commercial                        | Standard                   |
|                         | PSD312L25 KA | 250          | 44-pin CLCC     | L4                 | Commercial                        | Standard                   |
|                         | PSD312L30 A  | 300          | 44-pin PLCC     | J2                 | Commercial                        | Standard                   |
|                         | PSD312L30 KA | 300          | 44-pin CLCC     | L4                 | Commercial                        | Standard                   |

# PSD303L

| Key Features | Single Chip Programmable Peripheral<br>for Microcontroller-based Applications                                       | <ul> <li>IM bit of UV EPROM</li> <li>Configurable as 128K x 8 or as 64K x 16</li> <li>Divides into 8 arguel manaphle blacks</li> </ul> |
|--------------|---------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|
|              | 3.0 to 5.5 Volt Operation                                                                                           | <ul> <li>Divides into 8 equal mappable blocks<br/>for optimized mapping</li> </ul>                                                     |
|              | 19 Individually Configurable I/O pins<br>that can be used as:                                                       | <ul> <li>Block resolution is 16K x 8 or 8K x 16</li> <li>250 ns EPROM access time, including</li> </ul>                                |
|              | Microcontroller I/O port expansion     Programmable Address Decoder                                                 | input latches and PAD address decoding.                                                                                                |
|              | (PAD) I/O                                                                                                           | 16 Kbit Static RAM                                                                                                                     |
|              | Latched address output     Open drain or CMOS                                                                       | <ul> <li>Configurable as 2K x 8 or as 1K x 16</li> <li>250 ns SRAM access time, including</li> </ul>                                   |
|              | Two Programmable Arrays<br>(PAD A & PAD B)                                                                          | input latches and PAD address decoding                                                                                                 |
|              | <ul> <li>Total of 40 Product Terms and up to<br/>18 Inputs and 24 Outputs</li> </ul>                                | <ul> <li>Address/Data Track Mode</li> <li>Enables easy Interface to Shared</li> </ul>                                                  |
|              | <ul> <li>Direct Address Decoding up to 1 Meg<br/>address space and up to 16 Meg<br/>with paging</li> </ul>          | Resources (e.g., Mail Box SRAM) with<br>other Microcontrollers or a Host<br>Processor                                                  |
|              | - Logic replacement                                                                                                 | CMiser-Bit                                                                                                                             |
|              | "No Glue" Microcontroller Chip-Set                                                                                  | Programmable option to further reduce                                                                                                  |
|              | <ul> <li>Built-in address latches for multiplexed<br/>address/data bus</li> </ul>                                   | power consumption                                                                                                                      |
|              | <ul> <li>Non-multiplexed address/data bus<br/>mode</li> </ul>                                                       | <ul> <li>Built-In Security</li> <li>Locks the PSD303L and PAD Decoding</li> </ul>                                                      |
|              | <ul> <li>Selectable 8 or 16 bit data bus width</li> </ul>                                                           | Configuration                                                                                                                          |
|              | - ALE and Reset polarity programmable                                                                               | Available in a Choice of Packages                                                                                                      |
|              | <ul> <li>Selectable modes for read and write<br/>control bus as RD/WR, R/W/E, or</li> </ul>                         | — 44 Pin PLDCC and CLDCC                                                                                                               |
|              | R/W/DS<br>— BHE pin for byte select in 16-bit mode                                                                  | Simple Menu-Driven Software:<br>Configure the PSD303L on an IBM PC                                                                     |
|              | PSEN pin for 8051 users                                                                                             | Pin and Functionally Compatible with<br>the PSD3XX and PSD3XXL Series                                                                  |
|              | Built-In Page Logic                                                                                                 | THE LODONN AND LODONNE ORINO                                                                                                           |
|              | <ul> <li>To Expand the Address Space of<br/>Microcontrollers with Limited Address<br/>Space Capabilities</li> </ul> |                                                                                                                                        |
|              | - Up to 16 pages                                                                                                    |                                                                                                                                        |
|              |                                                                                                                     |                                                                                                                                        |
|              |                                                                                                                     |                                                                                                                                        |
|              |                                                                                                                     |                                                                                                                                        |

Absolute Maximum Ratings<sup>1</sup>

# 3-volt single-chip microcontroller peripheral

## PSD303L

| Symbol           | Parameter                     | <b>Condition</b>    | Min   | Max   | Unit |  |
|------------------|-------------------------------|---------------------|-------|-------|------|--|
| т                | Storage Temperature           | CERAMIC             | - 65  | + 150 | °C   |  |
| T <sub>STG</sub> | Slorage remperature           | PLASTIC             | - 65  | + 125 | °C   |  |
| T <sub>STG</sub> | Storage Temperature           |                     | - 65  | + 150 | °C   |  |
|                  | Voltage on any Pin            | With Respect to GND | - 0.6 | + 7   | V    |  |
| V <sub>PP</sub>  | Programming<br>Supply Voltage | With Respect to GND | - 0.6 | + 14  | v    |  |
| V <sub>cc</sub>  | Supply Voltage                | With Respect to GND | - 0.6 | + 7   | V    |  |
|                  | ESD Protection                |                     |       | >2000 | V    |  |

**NOTE:** 1. Stresses above those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to Absolute Maximum Rating conditions for extended periods of time may affect device reliability.

| Operating<br>Range | Range      | Temperature   | V <sub>CC</sub> |
|--------------------|------------|---------------|-----------------|
| nanye              | Commercial | 0° C to +70°C | 3.0 V to 5.5 V  |

| Recommended<br>Operating | Symbol          | Parameter                | Conditions                                 | Min                 | Тур | Max                   | Unit |
|--------------------------|-----------------|--------------------------|--------------------------------------------|---------------------|-----|-----------------------|------|
| Operating<br>Conditions  | V <sub>cc</sub> | Supply Voltage           | All Speeds                                 | 3.0                 | 3.3 | 5.5                   | V    |
| oonuntiona               | V <sub>IH</sub> | High-level Input Voltage | $V_{CC} = 3.0 \text{ V to } 5.5 \text{ V}$ | 0.7 V <sub>CC</sub> |     | V <sub>CC</sub> + 0.5 | V    |
|                          | V <sub>IL</sub> | Low-level Input Voltage  | V <sub>CC</sub> = 3.0 V to 5.5 V           | - 0.5               |     | 0.3 V <sub>CC</sub>   | v    |

DC

**Characteristics** 

# 3-volt single-chip microcontroller peripheral

PSD303L

|                                 |                                                                                       |                                                     |      |      |      | CMiser = 1<br>Subtract: |     | -   |     |
|---------------------------------|---------------------------------------------------------------------------------------|-----------------------------------------------------|------|------|------|-------------------------|-----|-----|-----|
| Symbol                          | Parameter                                                                             | Conditions                                          | Min  | Тур  | Max  | Min                     | Тур | Max | Uni |
| VoL Output Low                  | I <sub>OL</sub> = 20 μA<br>V <sub>CC</sub> = 3.0 V                                    |                                                     | 0.01 | 0.1  |      |                         |     | v   |     |
| VOL                             | Voltage                                                                               | I <sub>OL</sub> = 4 mA<br>V <sub>CC</sub> = 3.0 V   |      | 0.15 | 0.4  |                         |     |     | v   |
| V <sub>OH</sub>                 | Output High                                                                           | I <sub>OH</sub> = -20 μA<br>V <sub>CC</sub> = 3.0 V | 2.9  | 2.99 |      |                         |     |     | v   |
| VOH                             | Voltage                                                                               | I <sub>OH</sub> = -1 mA<br>V <sub>CC</sub> = 3.0 V  | 2.4  | 2.6  |      |                         |     |     | v   |
| I <sub>SB1</sub>                | V <sub>CC</sub> Standby<br>Current (CMOS)<br>(Notes 2 and 3)                          | V <sub>CC</sub> = 3.3 V                             |      | 1    | 5    |                         |     |     | μA  |
| 1                               | Active Current<br>(CMOS) (No<br>Internal Memory<br>Block Selected)<br>(Notes 2 and 5) | V <sub>CC</sub> = 3.3 V<br>(Note 5)                 |      | 6    | 12   |                         | 3.0 | 5   | mA  |
| ICC1                            |                                                                                       | V <sub>CC</sub> = 3.3 V<br>(Note 6)                 |      | 10   | 20   |                         | 3,0 | 5   | mA  |
| Active Current<br>(CMOS) (EPROM | V <sub>CC</sub> = 3.3 V<br>(Notes 5<br>and 7)                                         |                                                     | 6    | 12   |      | 0                       | 0   | mA  |     |
|                                 | Block Selected)<br>(Notes 2 and 5)                                                    | V <sub>CC</sub> = 3.3 V<br>(Note 6<br>and 7)        |      | 10   | 20   |                         | 0   | 0   | mA  |
| loca                            | Active Current<br>(CMOS) (SRAM<br>Block Selected)<br>(Notes 2 and 5)                  | V <sub>CC</sub> = 3.3 V<br>(Note 5<br>and 7)        |      | 20   | 33   |                         | 3   | 5   | mA  |
| .003                            |                                                                                       | V <sub>CC</sub> = 3.3 V<br>(Notes 6<br>and 7)       |      | 24   | 40   |                         | 3   | 5   | mA  |
| ILI                             | Input Leakage<br>Current                                                              | V <sub>IN</sub> = V <sub>CC</sub><br>or GND         | -1   | ±0.1 | 1    |                         |     |     | μA  |
| ILO                             | Output Leakage<br>Current                                                             | V <sub>OUT</sub> = V <sub>CC</sub><br>or GND        | -10  | ±5   | - 10 |                         |     |     | μΑ  |

NOTES: 2. CMOS inputs: GND  $\pm$  0.3 V or V\_{CC}  $\pm$  0.3V.

3. CSI/A19 is high and the part is in a power-down configuration mode.

4. Add 2.0 mA/MHz for AC power component (power = AC + DC).

5. Ten (10) PAD product terms active. (Add 190  $\mu A$  per product term, typical, or 240  $\mu A$  per product term maximum.)

6. Forty (40) PAD product terms active.

7. In 8-bit mode, an additional 3 mA Max. can be saved under CMiser.

PSD303L



The Normalized Supply Current vs. Supply Voltage graph shown above, provides a multiplier for any  $I_{SB}$  or  $I_{CC}$  value in the D.C. Characteristics table. As noted, it is normalized for a supply voltage of 3.3 volts. Since device characterization data shows very little supply current difference over speed, the multiplier includes all frequencies of operation from standby to quiescent to full dynamic speed. To use, calculate the supply current at 3.3 volts for your operation configuration using the D.C. Characteristics table. Then multiply that value by the Supply Current Multiplier for the supply voltage actually being used.

# 3-volt single-chip microcontroller peripheral

PSD303L

| AC<br>Characteristics <sup>(8)</sup> |        |                                                                                       | -2  | 25  | -3  | 80  | ONlines 1          |      |
|--------------------------------------|--------|---------------------------------------------------------------------------------------|-----|-----|-----|-----|--------------------|------|
| (See Timing<br>Diagrams)             | Symbol | Parameter                                                                             | Min | Max | Min | Max | CMiser = 1<br>Add: | Unit |
| Diayianisj                           | T1     | ALE or AS Pulse Width                                                                 | 75  |     | 80  |     |                    | ns   |
|                                      | T2     | Address Set-up Time                                                                   | 30  |     | 35  |     |                    | ns   |
|                                      | T3     | Address Hold Time                                                                     | 30  |     | 35  |     | 0                  | ns   |
|                                      | T4     | Leading Edge of Read to Data Active                                                   | 0   |     | 0   |     | 0                  | ns   |
|                                      | T5     | ALE Valid to Data Valid                                                               |     | 250 |     | 300 | 25                 | ns   |
|                                      | T6     | Address Valid to Data Valid                                                           |     | 250 |     | 300 | 25                 | ns   |
|                                      | T7     | CSI Active to Data Valid                                                              |     | 275 |     | 325 | 30                 | ns   |
|                                      | Т8     | Leading Edge of Read<br>to Data Valid                                                 |     | 90  |     | 95  | 0                  | ns   |
|                                      | Т9     | Read Data Hold Time                                                                   | 0   |     | 0   |     | 0                  | ns   |
|                                      | T10    | Trailing Edge of Read<br>to Data High-Z                                               |     | 50  |     | 55  | 0                  | ns   |
|                                      | T11    | Trailing Edge of ALE or AS to Leading Edge of Write                                   |     | 40  |     | 45  |                    | ns   |
|                                      | T12    | RD, E, PSEN, DS Pulse Width                                                           | 100 |     | 110 |     | 0                  | ns   |
|                                      | T12A   | WR Pulse Width                                                                        | 90  |     | 95  |     | 0                  | ns   |
|                                      | T13    | Trailing Edge of Write or Read to Leading Edge of ALE or AS                           | 0   |     | 0   |     | 0                  | ns   |
|                                      | T14    | Address Valid to Trailing<br>Edge of Write                                            | 250 |     | 300 |     | 0                  | ns   |
|                                      | T15    | CSI Active to Trailing Edge<br>of Write                                               | 275 |     | 375 |     | 0                  | ns   |
|                                      | T16    | Write Data Set-up Time                                                                | 60  |     | 65  |     | 0                  | ns   |
|                                      | T17    | Write Data Hold Time                                                                  | 25  |     | 30  |     | 0                  | ns   |
|                                      | T18    | Port to Data Out Valid<br>Propagation Delay                                           | -   | 70  |     | 75  | 0                  | ns   |
|                                      | T19    | Port Input Hold Time                                                                  | 0   |     | 0   |     | 0                  | ns   |
|                                      | T20    | Trailing Edge of Write to Port<br>Output Valid                                        | 100 |     | 110 |     | 0                  | ns   |
|                                      | T21    | ADi or Control to CSOi Valid                                                          | 6   | 80  | 5   | 85  | 0                  | ns   |
|                                      | T22    | ADi or Control to CSOi Invalid                                                        | 4   | 80  | 4   | 85  | 0                  | ns   |
|                                      | Т23    | Track Mode Address Propagation<br>Delay: CSADOUT1 Already True                        |     | 70  |     | 75  | 0                  | ns   |
|                                      | T23A   | Track Mode Address<br>Propagation Delay:<br>CSADOUT1 Becomes True<br>During ALE or AS |     | 100 |     | 110 | 0                  | ns   |

| NOTE: 8. | These AC | Characteristics | are for V | /CC = 3.0 - 3.6V. |
|----------|----------|-----------------|-----------|-------------------|
|----------|----------|-----------------|-----------|-------------------|

# 3-volt single-chip microcontroller peripheral

PSD303L

| AC<br>Characteristics |        |                                                              | -2  | 5   | -3  | 0   |                    |      |
|-----------------------|--------|--------------------------------------------------------------|-----|-----|-----|-----|--------------------|------|
| (Cont.)               | Symbol | Parameter                                                    | Min | Max | Min | Max | CMiser = 1<br>Add: | Unit |
|                       | T24    | Track Mode Trailing Edge of ALE<br>or AS to Address High-Z   |     | 60  |     | 65  | 0                  | ns   |
|                       | T25    | Track Mode Read Propagation<br>Delay                         |     | 70  |     | 75  | 0                  | ns   |
|                       | T26    | Track Mode Read Hold Time                                    | 10  | 70  | 10  | 75  |                    | ns   |
|                       | T27    | Track Mode Write Cycle,<br>Data Propagation Delay            |     | 60  |     | 65  | 0                  | ns   |
|                       | T28    | Track Mode Write Cycle,<br>Write to Data Propagation Delay   | 7   | 80  | 7   | 85  | 0                  | ns   |
|                       | T29    | Hold Time of Port A Valid<br>During Write CSOi Trailing Edge | 4   |     | 4   |     | 0                  | ns   |
|                       | T30    | CSI Active to CSOi Active                                    | 9   | 110 | 8   | 120 | 0                  | ns   |
|                       | T31    | CSI Inactive to CSOi Inactive                                | 9   | 110 | 8   | 120 | 0                  | ns   |
|                       | T32    | Direct PAD Input as Hold Time                                | 24  |     | 30  |     | 0                  | ns   |
|                       | T33    | R/W Active to E or DS Start                                  | 60  |     | 65  |     | 0                  | ns   |
|                       | T34    | E or $\overline{\text{DS}}$ End to R/W                       | 60  |     | 65  |     | 0                  | ns   |
|                       | T35    | AS Inactive to E high                                        | 40  |     | 45  |     | 0                  | ns   |
|                       | T36    | Address to Leading Edge of Write                             | 50  |     | 60  |     | 0                  | ns   |

NOTES: 9. ADi = any address line. 10. CSOi = any of the chip-select output signals coming through Port B (CS0–CS7) or through Port C (CS8–CS10).

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

12. Control signals RD/E/DS or WR or R/W.

#### Philips Semiconductors Microcontroller Peripherals

#### 3-volt single-chip microcontroller peripheral PSD303L Figure 2. AC Testing 0.9 V<sub>CC</sub> " Input/Output Waveform TEST 1.5V POINT oV -\$\$ Figure 3. 2.0 V AČ Testing Load Circuit 400 Ω DEVICE UNDER TEST C<sub>L</sub> = 30 pF (INCLUDING SCOPE AND JIG CAPACITANCE) Figure 4. The Reset VIH Cycle (RESET) V<sub>IL</sub> 500 ns 500 ns

**RESET HIGH** 

PART OPERATIONAL

RESET LOW

#### May, 1993

267

## PSD303L



# PSD303L





# PSD303L



### PSD303L







#### Philips Semiconductors Microcontroller Peripherals

# 3-volt single-chip microcontroller peripheral

#### PSD303L



PSD303L



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

### PSD303L



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



Preliminary specification



PSD303L





PSD303L

### Figure 15. Port A as AD0 – AD7 Timing (Track Mode), CRRWR = 1



19. Multiplexed PAD inputs: any of the following PAD inputs that are latched by the ALE (or AS) in the multiplexed modes: A11/AD11-A15/AD15, CSI/A19 as ALE dependent A19, ALE dependent PC0-PC2.

20. CSOi product terms can include any of the PAD input signals except for reset and CSI.

## Field-programmable microcontroller peripheral

### PSD303L

| PIN                       |  |
|---------------------------|--|
| Capacitance <sup>21</sup> |  |

\_

| Symbol | Parameter                           | <b>Conditions</b>      | Typical <sup>22</sup> | Max | Unit |
|--------|-------------------------------------|------------------------|-----------------------|-----|------|
| CIN    | Capacitance (for input pins only)   | $V_{IN} = 0 V$         | 4                     | 6   | pF   |
| Солт   | Capacitance (for input/output pins) | V <sub>OUT</sub> = 0 V | 8                     | 12  | pF   |
| CVPP   | Capacitance (for WR/VPP or R/W/VPP) | $V_{PP} = 0 V$         | 18                    | 25  | pF   |

NOTES: 21. This parameter is only sampled and is not 100% tested. 22. Typical values are for T<sub>A</sub> = 25°C and nominal supply voltages.

#### Erasure and Programming

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

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

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

# Field-programmable microcontroller peripheral

# PSD303L

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

PSD303L



# Field-programmable microcontroller peripheral

# PSD303L

| Ordering<br>Information | Part Number  | Spd.<br>(ns) | Package<br>Type | Package<br>Drawing | Operating<br>Temperature<br>Range | Manufacturing<br>Procedure |
|-------------------------|--------------|--------------|-----------------|--------------------|-----------------------------------|----------------------------|
|                         | PSD303L25 A  | 250          | 44-pin PLCC     | J2                 | Commercial                        | Standard                   |
|                         | PSD303L25 KA | 250          | 44-pin CLCC     | L4                 | Commercial                        | Standard                   |
|                         | PSD303L30 A  | 300          | 44-pin PLCC     | J2                 | Commercial                        | Standard                   |
|                         | PSD303L30 KA | 300          | 44-pin CLCC     | L4                 | Commercial                        | Standard                   |

# Key Features

- Single Chip Programmable Peripheral for Microcontroller-based Applications
- 3.0 to 5.5 Volt Operation
- □ 19 Individually Configurable I/O pins that can be used as:
- Microcontroller I/O port expansion
- Programmable Address Decoder (PAD) I/O
- Latched address output
- Open drain or CMOS
- Two Programmable Arrays (PAD A & PAD B)
- --- Total of 40 Product Terms and up to 18 Inputs and 24 Outputs
- Direct Address Decoding up to 1 Meg address space and up to 16 Meg with paging
- Logic replacement
- "No Glue" Microcontroller Chip-Set
- Built-in address latches for multiplexed address/data bus
- Non-multiplexed address/data bus mode
- 8-bit data bus width
- ALE and Reset polarity programmable
- Selectable modes for read and write control bus as RD/WR, R/W/E, or R/W/DS
- PSEN pin for 8051 users
- Built-In Page Logic
- To Expand the Address Space of Microcontrollers with Limited Address Space Capabilities
- Up to 16 pages

- IM bit of UV EPROM
- Configurable as 128K x 8
- --- Divides into 8 equal mappable blocks for optimized mapping
- Block resolution is 16K x 8
- 250 ns EPROM access time, including input latches and PAD address decoding.
- 16 Kbit Static RAM
- Configurable as 2K x 8
- 250 ns SRAM access time, including input latches and PAD address decoding
- Address/Data Track Mode
- Enables easy Interface to Shared Resources (e.g., Mail Box SRAM) with other Microcontrollers or a Host Processor
- CMiser-Bit
- Programmable option to further reduce power consumption
- Built-In Security
- Locks the PSD313L and PAD Decoding Configuration
- Available in a Choice of Packages
- 44 Pin PLDCC and CLDCC
- Simple Menu-Driven Software: Configure the PSD313L on an IBM PC
- Pin and Functionally Compatible with the PSD3XX and PSD3XXL Series

### PSD313L

Absolute Maximum Ratings<sup>1</sup>

# 3-volt single-chip microcontroller peripheral

# PSD313L

| Symbol           | Parameter                     | Condition           | Min   | Max   | Unit |
|------------------|-------------------------------|---------------------|-------|-------|------|
| T                |                               | CERAMIC             | - 65  | + 150 | °C   |
| T <sub>STG</sub> | Storage Temperature           | PLASTIC             | - 65  | + 125 | °C   |
| T <sub>STG</sub> | Storage Temperature           |                     | - 65  | + 150 | °C   |
|                  | Voltage on any Pin            | With Respect to GND | - 0.6 | +7    | V    |
| V <sub>PP</sub>  | Programming<br>Supply Voltage | With Respect to GND | - 0.6 | + 14  | v    |
| V <sub>cc</sub>  | Supply Voltage                | With Respect to GND | - 0.6 | +7    | V    |
|                  | ESD Protection                |                     |       | >2000 | V    |

**NOTE:** 1. Stresses above those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to Absolute Maximum Rating conditions for extended periods of time may affect device reliability.

| <i>Operating<br/>Range</i> | Range      | Temperature   | V <sub>CC</sub> |
|----------------------------|------------|---------------|-----------------|
| nanyt                      | Commercial | 0° C to +70°C | 3.0 V to 5.5 V  |

| Recommended<br>Operating | Symbol          | Parameter                | Conditions                | Min           | Тур | Max                   | Unit |
|--------------------------|-----------------|--------------------------|---------------------------|---------------|-----|-----------------------|------|
| Conditions               | V <sub>cc</sub> | Supply Voltage           | All Speeds                | 3.0           | 3.3 | 5.5                   | V    |
| oonuntions               | ViH             | High-level Input Voltage | $V_{CC}$ = 3.0 V to 5.5 V | $0.7  V_{CC}$ |     | V <sub>CC</sub> + 0.5 | V    |
|                          | VIL             | Low-level Input Voltage  | $V_{CC}$ = 3.0 V to 5.5 V | - 0.5         |     | 0.3 V <sub>CC</sub>   | V    |

DC

**Characteristics** 

# 3-volt single-chip microcontroller peripheral

PSD313L

|                  |                                                                                                        |                                                     |     |      |     |     | Niser<br>Ibtrac | -   |      |
|------------------|--------------------------------------------------------------------------------------------------------|-----------------------------------------------------|-----|------|-----|-----|-----------------|-----|------|
| Symbol           | Parameter                                                                                              | Conditions                                          | Min | Тур  | Max | Min | Тур             | Max | Unit |
| Vol              | Output Low                                                                                             | I <sub>OL</sub> = 20 μA<br>V <sub>CC</sub> = 3.0 V  |     | 0.01 | 0.1 |     |                 |     | v    |
| , OL             | Voltage                                                                                                | l <sub>OL</sub> = 4 mA<br>V <sub>CC</sub> = 3.0 V   |     | 0.15 | 0.4 |     |                 |     | v    |
| V <sub>он</sub>  | Output High                                                                                            | I <sub>OH</sub> = -20 μA<br>V <sub>CC</sub> = 3.0 V | 2.9 | 2.99 |     |     |                 |     | v    |
| · On             | Voltage                                                                                                | l <sub>OH</sub> = -1 mA<br>V <sub>CC</sub> = 3.0 V  | 2.4 | 2.6  |     |     |                 |     | v    |
| I <sub>SB1</sub> | V <sub>CC</sub> Standby<br>Current (CMOS)<br>(Notes 2 and 3)                                           | V <sub>CC</sub> = 3.3 V                             |     | 1    | 5   |     |                 |     | μA   |
|                  | Active Current<br>(CMOS) (No<br>I <sub>CC1</sub> Internal Memory<br>Block Selected)<br>(Notes 2 and 5) | V <sub>CC</sub> = 3.3 V<br>(Note 5)                 |     | 6    | 12  |     | 3.0             | 5   | mA   |
| ICC1             |                                                                                                        | V <sub>CC</sub> = 3.3 V<br>(Note 6)                 |     | 10   | 20  |     | 3.0             | 5   | mA   |
| I <sub>CC2</sub> | Active Current<br>(CMOS) (EPROM                                                                        | V <sub>CC</sub> = 3.3 V<br>(Note 5)                 |     | 6    | 12  |     | 2               | 3   | mA   |
| 1002             | Block Selected)<br>(Notes 2 and 5)                                                                     | V <sub>CC</sub> = 3.3 V<br>(Note 6)                 |     | 10   | 20  |     | 2               | 3   | mA   |
| I <sub>CC3</sub> | Active Current<br>(CMOS) (SRAM                                                                         | V <sub>CC</sub> = 3.3 V<br>(Note 5)                 |     | 20   | 33  |     | 5               | 8   | mA   |
|                  | Block Selected)<br>(Notes 2 and 5)                                                                     | V <sub>CC</sub> = 3.3 V<br>(Note 6)                 |     | 24   | 40  |     | 5               | 8   | mA   |
| I <sub>LI</sub>  | Input Leakage<br>Current                                                                               | V <sub>IN</sub> = V <sub>CC</sub><br>or GND         | -1  | ±0.1 | 1   |     |                 |     | μA   |
| ILO              | Output Leakage<br>Current                                                                              | V <sub>OUT</sub> = V <sub>CC</sub><br>or GND        | -10 | ±5   | 10  |     |                 |     | μA   |

NOTES: 2. CMOS inputs: GND  $\pm$  0.3 V or V<sub>CC</sub>  $\pm$  0.3V.

3. CSI/A19 is high and the part is in a power-down configuration mode.

4. Add 2.0 mA/MHz for AC power component (power = AC + DC).

5. Ten (10) PAD product terms active. (Add 190 μA per product term, typical, or 240 μA per product term maximum.)

6. Forty (40) PAD product terms active.

# PSD313L



The Normalized Supply Current vs. Supply Voltage graph shown above, provides a multiplier for any  $I_{SB}$  or  $I_{CC}$  value in the D.C. Characteristics table. As noted, it is normalized for a supply voltage of 3.3 volts. Since device characterization data shows very little supply current difference over speed, the multiplier includes all frequencies of operation from standby to quiescent to full dynamic speed. To use, calculate the supply current at 3.3 volts for your operation configuration using the D.C. Characteristics table. Then multiply that value by the Supply Current Multiplier for the supply voltage actually being used.

# 3-volt single-chip microcontroller peripheral

PSD313L

| IC<br>Characteristics <sup>(8)</sup> |                  |                                                                                       | -2  | 25  | -3  | 80  | 01/1               |      |
|--------------------------------------|------------------|---------------------------------------------------------------------------------------|-----|-----|-----|-----|--------------------|------|
| See Timing<br>Diagrams)              | Symbol Parameter |                                                                                       | Min | Max | Min | Max | CMiser = 1<br>Add: | Unit |
| nayi aməj                            | T1               | ALE or AS Pulse Width                                                                 | 75  |     | 80  |     |                    | ns   |
|                                      | T2               | Address Set-up Time                                                                   | 30  |     | 35  |     |                    | ns   |
|                                      | Т3               | Address Hold Time                                                                     | 30  |     | 35  |     | 0                  | ns   |
|                                      | T4               | Leading Edge of Read to Data Active                                                   | 0   |     | 0   |     | 0                  | ns   |
|                                      | T5               | ALE Valid to Data Valid                                                               |     | 250 |     | 300 | 25                 | ns   |
|                                      | Т6               | Address Valid to Data Valid                                                           |     | 250 |     | 300 | 25                 | ns   |
|                                      | T7               | CSI Active to Data Valid                                                              |     | 275 |     | 325 | 30                 | ns   |
|                                      | Т8               | Leading Edge of Read<br>to Data Valid                                                 |     | 90  |     | 95  | 0                  | ns   |
|                                      | Т9               | Read Data Hold Time                                                                   | 0   |     | 0   |     | 0                  | ns   |
|                                      | T10              | Trailing Edge of Read<br>to Data High-Z                                               |     | 50  |     | 55  | 0                  | ns   |
|                                      | T11              | Trailing Edge of ALE or AS to Leading Edge of Write                                   |     | 40  |     | 45  |                    | ns   |
|                                      | T12              | RD, E, PSEN, DS Pulse Width                                                           | 100 |     | 110 |     | 0                  | ns   |
|                                      | T12A             | WR Pulse Width                                                                        | 90  |     | 95  |     | 0                  | ns   |
|                                      | T13              | Trailing Edge of Write or Read to Leading Edge of ALE or AS                           | 0   |     | 0   |     | 0                  | ns   |
|                                      | T14              | Address Valid to Trailing<br>Edge of Write                                            | 250 |     | 300 |     | 0                  | ns   |
|                                      | T15              | CSI Active to Trailing Edge<br>of Write                                               | 275 |     | 375 |     | 0                  | ns   |
|                                      | T16              | Write Data Set-up Time                                                                | 60  |     | 65  |     | 0                  | ns   |
|                                      | T17              | Write Data Hold Time                                                                  | 25  |     | 30  |     | 0                  | ns   |
|                                      | T18              | Port to Data Out Valid<br>Propagation Delay                                           |     | 70  |     | 75  | 0                  | ns   |
|                                      | T19              | Port Input Hold Time                                                                  | 0   |     | 0   |     | 0                  | ns   |
|                                      | T20              | Trailing Edge of Write to Port<br>Output Valid                                        | 100 |     | 110 |     | 0                  | ns   |
|                                      | T21              | ADi or Control to CSOi Valid                                                          | 6   | 80  | 5   | 85  | 0                  | ns   |
|                                      | T22              | ADi or Control to CSOi Invalid                                                        | 4   | 80  | 4   | 85  | 0                  | ns   |
|                                      | T23              | Track Mode Address Propagation<br>Delay: CSADOUT1 Already True                        |     | 70  |     | 75  | 0                  | ns   |
|                                      | T23A             | Track Mode Address<br>Propagation Delay:<br>CSADOUT1 Becomes True<br>During ALE or AS |     | 100 |     | 110 | 0                  | ns   |

NOTE: 8. These AC Characteristics are for VCC = 3.0 - 3.6V.

AC

(Cont.)

**Characteristics** 

# 3-volt single-chip microcontroller peripheral

PSD313L

|        |                                                              | -2  | 25  | -3  | 80  | _                  |      |
|--------|--------------------------------------------------------------|-----|-----|-----|-----|--------------------|------|
| Symbol | Parameter                                                    | Min | Max | Min | Max | CMiser = 1<br>Add: | Unit |
| T24    | Track Mode Trailing Edge of ALE<br>or AS to Address High-Z   |     | 60  | -   | 65  | 0                  | ns   |
| T25    | Track Mode Read Propagation<br>Delay                         |     | 70  |     | 75  | 0                  | ns   |
| T26    | Track Mode Read Hold Time                                    | 10  | 70  | 10  | 75  |                    | ns   |
| T27    | Track Mode Write Cycle,<br>Data Propagation Delay            |     | 60  |     | 65  | 0                  | ns   |
| T28    | Track Mode Write Cycle,<br>Write to Data Propagation Delay   | 7   | 80  | 7   | 85  | 0                  | ns   |
| T29    | Hold Time of Port A Valid<br>During Write CSOi Trailing Edge | 4   |     | 4   |     | 0                  | ns   |
| T30    | CSI Active to CSOi Active                                    | 9   | 110 | 8   | 120 | 0                  | ns   |
| T31    | CSI Inactive to CSOi Inactive                                | 9   | 110 | 8   | 120 | 0                  | ns   |
| T32    | Direct PAD Input as Hold Time                                | 24  |     | 30  |     | 0                  | ns   |
| T33    | $R/W$ Active to E or $\overline{DS}$ Start                   | 60  |     | 65  |     | 0                  | ns   |
| T34    | E or DS End to R/W                                           | 60  |     | 65  |     | 0                  | ns   |
| T35    | AS Inactive to E high                                        | 40  |     | 45  |     | 0                  | ns   |
| T36    | Address to Leading Edge of Write                             | 50  |     | 60  |     | 0                  | ns   |

NOTES: 9. ADi = any address line.

10. CSOi = any of the chip-select output signals coming through Port B (CS0-CS7) or through Port C (CS8-CS10).

11. Direct PAD input = any of the following direct PAD input lines: CSI/A19 as transparent A19, RD/E/DS, WR or RW, transparent PC0–PC2, ALE (or AS).

12. Control signals RD/E/DS or WR or R/W.

# PSD313L



# PSD313L

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



# PSD313L

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



### PSD313L



# PSD313L



PSD313L



# PSD313L

### Figure 10. Port A as ADO – AD7 Timing (Track Mode), CRRWR = 0



# Field-programmable microcontroller peripheral

PSD313L



### Figure 11. Port A as ADO – AD7 Timing (Track Mode), CRRWR = 1

*Notes for Timing Diagrams* 

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

PSD313L

Pin Capacitance<sup>21</sup>  $T_A = 25 \circ C, f = 1 MHz$ 

| Symbol | Parameter                                                            | Conditions             | Typical <sup>22</sup> | Max | Unit |
|--------|----------------------------------------------------------------------|------------------------|-----------------------|-----|------|
| CIN    | Capacitance (for input pins only)                                    | V <sub>IN</sub> = 0 V  | 4                     | 6   | pF   |
| Cout   | Capacitance (for input/output pins)                                  | V <sub>OUT</sub> = 0 V | 8                     | 12  | рF   |
| CVPP   | Capacitance (for $\overline{WR}/V_{PP}$ or $R/\overline{W}/V_{PP}$ ) | V <sub>PP</sub> = 0 V  | 18                    | 25  | pF   |

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

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

#### Erasure and Programming

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

The PSD313L and similar devices will erase with light sources having wavelengths shorter than 4000 Å. Although the erasure times will be much longer than with UV sources at 2537 Å, exposure to fluorescent light and sunlight eventually

erases the device. For maximum system reliability, these sources should be avoided. If used in such an environment, the package windows should be covered by an opaque substance.

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

# PSD313L

Preliminary specification

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

PSD313L



PSD313L

| Ordering<br>Information | Part Number  | Spd.<br>(ns) | Package<br>Type | Package<br>Drawing | Operating<br>Temperature<br>Range | Manufacturing<br>Procedure |
|-------------------------|--------------|--------------|-----------------|--------------------|-----------------------------------|----------------------------|
|                         | PSD313L25 A  | 250          | 44-pin PLCC     | J2                 | Commercial                        | Standard                   |
|                         | PSD313L25 KA | 250          | 44-pin CLCC     | L.4                | Commercial                        | Standard                   |
|                         | PSD313L30 A  | 300          | 44-pin PLCC     | J2                 | Commercial                        | Standard                   |
|                         | PSD313L30 KA | 300          | 44-pin CLCC     | L4                 | Commercial                        | Standard                   |

# Section 3 Application Notes

PSD3XX Programmable Microcontroller Peripherals

#### INDEX

| Application Note 011 | The PSD3XX Device Description                                                              |
|----------------------|--------------------------------------------------------------------------------------------|
| Application Note 013 | The PSD301 Streamlines a<br>Microcontroller-Based<br>Smart Transmitter Design              |
| Application Note 014 | Using the PSD3XX PAD for<br>System Logic Replacement                                       |
| Application Note 015 | Using Memory Paging<br>with the PSD3XX                                                     |
| Application Note 016 | Power Considerations<br>in the PSD3XX                                                      |
| Application Note 018 | Security of Design in the PSD3XX413                                                        |
| Application Note 019 | The PSD311 Simplifies an<br>Eight Wire Cable Tester Design<br>and Increases Flexibility417 |
| Application Note 020 | Benefits of 16-Bit Design<br>with PSD3XX437                                                |

# PSD3XX

### **Contents**

### Chapter 1: PSD301 Device Description

| Introduction                                         |     |
|------------------------------------------------------|-----|
| Software Support for the PSD Family                  |     |
| PSD3XX Architecture and Pin Nomenclature             |     |
| Performance Characteristics                          |     |
| PSD3XX System Configuration for Port and I/O Options |     |
| Address Inputs                                       | 310 |
| PSD3XX Programmable Array Decoder (PAD)              |     |
| Microcontroller/Microprocessor Control Inputs        |     |
| Input and Output Ports                               |     |
| PSD3XX General System Configuration                  |     |
| PSD3XX Configuration for Port Reconstruction         |     |

### **Chapter 2: Applications**

| 8-Bit Microcontroller to PSD3XX Interface                                  | 319 |
|----------------------------------------------------------------------------|-----|
| Two PSD3XX Byte-Wide Interfaces to Intel 80C31                             | 321 |
| PSD3XX M68HC11 Byte-Wide Interface                                         | 323 |
| 8-Bit Non-Multiplexed PSD3XX Interface to M68008                           | 325 |
| 16-Bit Non-Multiplexed Address/Data PSD3XX Interface to M68000             | 327 |
| M68000/2X PSD3XX Applications                                              | 329 |
| 16-Bit Address/Data PSD3XX Interface to Intel 80186                        | 331 |
| 16-Bit Address/Data PSD3XX to Intel 80196 Interface                        | 333 |
| Interfacing the PSD3XX to 8-Bit Microprocessors Z80 and M6809 Applications | 333 |
| PSD3XX Interface to the Intel 80286                                        | 338 |
| External Peripherals to the PSD3XX/M68HC11 Configuration                   | 340 |
| Additional External SRAM                                                   | 342 |
| PD3XX Used in Track Mode                                                   | 346 |

### Chapter 3: Software Support

| Summary | / |
|---------|---|
|---------|---|

| Figures | Figure 1. | PSD3XX Supports CPU as a Complete Peripheral,<br>Memory, and Logic Subsystem | 305 |
|---------|-----------|------------------------------------------------------------------------------|-----|
|         | Cierura O |                                                                              |     |
|         | •         | PSD3XX Architecture                                                          |     |
|         | Figure 3. | 8-Bit Multiplexed Address/Data Mode                                          |     |
|         | Figure 4. | 16-Bit Multiplexed Address/Data Mode                                         |     |
|         | Figure 5. | Non-Multiplexed Mode 8-Bit Data Bus                                          |     |
|         | Figure 6. | Non-Multiplexed Mode 16-Bit Data Bus                                         | 310 |
|         | Figure 7. | PSD3XX Programmable Array Decoder                                            | 311 |
|         | Figure 8. | PSD3XX Port A Structure                                                      | 314 |
|         | Figure 9. | PSD3XX Port B Structure                                                      | 315 |
|         |           |                                                                              |     |

| <b>F</b> 1 |            |                                                         |     |
|------------|------------|---------------------------------------------------------|-----|
| Figures    | •          | Intel 80C31/PSD3XX Applications                         |     |
| (Cont.)    | -          | Intel 80C31/2/PSD3XX Applications                       |     |
|            | •          | M68HC11/PSD3XX Applications                             |     |
|            | •          | M68008/PSD3XX Applications                              |     |
|            | •          | M68000/PSD3XX Applications                              |     |
|            | Figure 15. | M68000/2X PSD3XX Applications                           | 330 |
|            | •          | Intel 80186/PSD3XX Applications                         |     |
|            |            | Intel 80196/PSD3XX Applications Open-Drain Drivers      |     |
|            | Figure 18. | Z80/PSD3XX Applications                                 | 336 |
|            | Figure 19. | 6809/PSD3XX Applications                                | 337 |
|            | -          | Intel 80286/PSD3XX Applications                         |     |
|            | Figure 21. | M68HC11/PSD3XX to M68230 Applications                   | 341 |
|            | Figure 22. | M68HC11/PSD3XX to 16K SRAM Applications                 | 343 |
|            | Figure 23. | SC80C451/PSD3XX to 16K SRAM Applications                | 345 |
|            | Figure 24. | Intel 80196/PSD3XX Track Mode to External SRAM          | 347 |
|            | Figure 25. | MAPLE Main Menu                                         | 349 |
|            | Figure 26. | MAPLE Menu with PARTNAME Submenu                        | 350 |
|            | Figure 27. | CONFIGURATION Menu                                      | 351 |
|            | Figure 28. | Port C Configuration Menu                               | 352 |
|            | Figure 29. | Port A Configuration Menu, Part 1                       | 352 |
|            | Figure 30. | Port A Configuration Menu, Part 2                       | 353 |
|            | Figure 31. | Port B Configuration Menu                               | 353 |
|            | Figure 32. | Address MAP Menu                                        | 354 |
|            | Figure 33. | Port B Configuration Menu with Address Map              | 355 |
| Tables     | Table 1.   | Port Base Address Offset                                |     |
|            | Table 2.   | Non-Volatile Configuration Bits                         | 317 |
|            | Table 3.   | Small Controller System with One 80C31 and One PSD3XX   | 319 |
|            | Table 4.   | 80C31 Interface to Two PSD3XX Devices with Power        |     |
|            |            | Economy Feature                                         | 321 |
|            | Table 5.   | M68HC11 to PSD3XX Interface                             | 323 |
|            | Table 6.   | M68008 to PSD3XX Interface                              | 325 |
|            | Table 7.   | M68000 Microprocessor to One PSD3XX Interface           | 327 |
|            | Table 8.   | M68000 Microprocessor to Two PSD3XX Devices in Parallel |     |
|            | Table 9.   | Intel 80196 to PSD3XX Configuration for CMOS Ports      |     |
|            | Table 10.  | Intel 80196 to PSD3XX Configuration for LED Drivers     |     |
|            | Table 11.  | Z80B to PSD3XX Interface                                |     |
|            | Table 12.  | M6809 to PSD3XX Interface                               |     |
|            | Table 13.  | Intel 80286 to PSD3XX Interface                         |     |
|            | Table 14.  | M68HC11/PSD3XX to External Peripheral M68230 Interface  |     |
|            | Table 15.  | M68HC11/PSD3XX Configured to Address Additional SRAM    |     |
|            | Table 16.  | SC80C451/PSD3XX Configured to Address Additional SRAM   |     |
|            | Table 17.  | Intel 80196 to PSD3XX Used to Access External SRAM      |     |
|            |            | in Track Mode                                           |     |
|            |            |                                                         |     |

# PSD3XX

# **Chapter 1**

### Introduction

The PSD3XX family of products include flexible I/O ports, PLD, Page Register, 256K to 1M EPROM, 16K bit SRAM and "Glueless" Logic Interface to the micro controller. The PSD3XX is ideal for microcontroller based applications where fast time-to-market, small form factor and low power consumption are essential. These applications include disk controllers, cellular phones, modems, fax machines, medical instrumentation, industrial control, automotive engine control and many others.

Traditionally, central processing units (CPUs) require the support of non-volatile memory for program storage, random access memory (RAM) for data storage, and some input/ output (I/O) capability to communicate with external devices. The addition of general logic circuitry is necessary to 'glue' the parts of the system together. Figure 1 shows a block diagram of such a system, configured with a CPU (or microprocessor). The typical microprocessor also has integrated into it onboard timers, a small amount of RAM and ROM, as well as a limited I/O capability.

The microprocessor (and often the microcontroller) requires additional external support EPROM and RAM memory, additional ports, memory mapping logic, and sometimes latches to separate address and data from a multiplexed address/data bus. Until very recently, designers had to create a discrete solution from a number of chips, or generate a full custom solution. Now, the PSD3XX integrates the different system support blocks into a single-chip solution. This relieves the designer from the constraint of thinking that memory mapping, ports, and address latch requirements should be developed from separate elements.



| Introduction<br>(Cont.)                               | This high integration of functionality into a single chip enables designers to reduce the overall chip count of the system. The result is increased system reliability, simpler PCB layout, and lower inventory and assembly costs. By integrating ports, latches, a Programmable Address Decoder (PAD), EPROM, and static RAM, the PSD3XX can bring the system solution down to only two chips: a microcontroller and a PSD3XX. The alternative solution would be discrete elements of RAM, EPROM, I/O mapped ports, and latches all mapped into the address scheme by a programmable logic device (PLD). This could escalate the chip count to 8–12 packages, depending on size and complexity.                                                                                                                                                                                                                                                                                                     | For larger systems, multiple PSD3XX 's can be<br>configured. Due to its versatility and flexibil-<br>ity, two or more PSDs can be cascaded either<br>horizontally (increasing bus width) or vertically<br>(increasing sub-system depth). This propor-<br>tionally increases the complement of memory,<br>I/O ports, and chip-selects without the need<br>for additional external glue logic.<br>An additional feature of the PSD3XX is its<br>ability to support a wide range of microcon-<br>trollers or microprocessors because it has<br>been designed with a wide range of configur-<br>able options. The designer can program any<br>one of a number of different options to create<br>specific compatibility with a host processor.<br>Furthermore, this can be done without the<br>need for external glue logic.                                                                                                                                                                                                     |
|-------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WSI Software<br>Support for the<br>PSD Family         | The PSD family can be easily configured<br>from a low-cost software support package<br>called MAPLE. Designed to run in an<br>IBM/PC environment, MAPLE makes<br>design and configuration of the PSD3XX a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | simple task. Memory mapping of EPROM<br>and RAM blocks replaces PLD-like equations<br>with user-friendly, high-level command<br>entries.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| <b>PSD3XX</b><br>Architecture and<br>Pin Nomenclature | The PSD3XX is available in a variety of 44-pin<br>packages (see the PSD3XX Data Sheet).<br>Figure 2 is a functional block diagram of the<br>PSD3XX that shows the pin functions, internal<br>architecture, and bus structure.<br>Inputs AD0–AD15 enter the PSD through<br>latches. These can be programmed to latch<br>the address/data inputs, removing the need<br>for such devices as the 74HCT373 or 573.<br>Alternatively, in the transparent mode they<br>simply buffer address inputs. The Address<br>Latch Enable (ALE) signal is available to<br>register a valid address input on the<br>AD0–AD15 lines; its active polarity is pro-<br>grammable. Another name for this input is<br>Address Strobe (AS). It provides the same<br>function and the same timing as the ALE, but<br>this pin name is more appropriate to Motor-<br>ola-type systems. When either ALE or AS is<br>valid, the latches are transparent; when<br>inactive, the address/data inputs on<br>AD0–AD15 remain latched. | The PSD3XX also contains a Programmable<br>Address Decoder (PAD). Figure 2 shows that<br>address inputs A11–A15 (and, possibly,<br>inputs A16–A19) go directly to the PAD.<br>Other inputs to the PAD include RD(E), WR<br>(R/W), and ALE(AS). Programming of the<br>PAD enables the designer to internally select<br>the EPROM banks via internal chip-select<br>lines ES0–ES7. An additional chip-select for<br>the internal SRAM is available through RS0.<br>Port C conveys either CS8–CS10 to external<br>devices or receives A16–A18 inputs, directing<br>them to the PAD. Also, A19 can be pro-<br>grammed to go directly into the PAD. Note<br>that these lines are not necessarily dedicated<br>to address inputs; they can be used as<br>general purpose logic inputs. Thus, the PAD<br>can be programmed to perform general<br>combinational logic without adding any 'glue<br>logic' to the overall system design. Address<br>inputs A16–A19 can be used as general<br>inputs to the PAD for implementing logic |



| <i>PSD3XX<br/>Architecture and<br/>Pin Nomenclature<br/>(Cont.)</i>  | equations, and not for address decoding. If<br>they are not used, A16–A19 are "don't care"<br>conditions in memory map allocation. (See<br>Figure 7 for a more detailed diagram of the<br>PAD.)<br>The internal port options (Ports A and B) are<br>both 8 bit-wide and can be programmed to act<br>as traditional I/O ports. Port C is a 3-bit port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | designed to output logic functions from the<br>PAD, receive address inputs A16–A18, or a<br>combination of both. Ports A and B, however,<br>are more complex because a number of<br>different options can be selected with regard<br>to system configuration. Figures 3, 4, 5, and<br>6 show the variety of configurations that are<br>available to these ports.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Performance<br>Characteristics                                       | Two key timing parameters associated with<br>the device are the EPROM/SRAM access<br>times and the propagation delay through<br>the PAD. The worst-case delay from valid<br>address input to valid data output is 120 ns<br>whether the address input is multiplexed or<br>not. The cycle time of the system is virtually<br>120 ns with a small margin for address<br>switching. This gives a system clock rate of                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | about 8.3 MHz. Considering the power-<br>down option, it takes 100 ns for active<br>power input enabled through the CSI to<br>valid data output. If the chip-select output<br>option is chosen for either Port B or Port C,<br>the propagation delay for address and<br>control input through the PAD to valid chip-<br>select output is 35 ns.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| <b>PSD3XX System</b><br>Configuration for<br>Port and I/O<br>Options | In this section, the EPROM and SRAM are treated as separate entities and the four options available for configuring the PSD301 in a processor system are detailed. Figure 3 shows an 8-bit data configuration for systems that multiplex 8-bits of data (D0–D7) with the corresponding address inputs (A0–A7). Lines A8–A15 are dedicated to higher-order address inputs. Ports A and B are then available for additional inputs, A16–A18 or chip-select outputs CS8–CS10. Port A also has the option of passing any one or all of the internally latched lower-order addresses (A0–A7) to the output. Another mode supported by Port A is called "track mode." In this mode, the PSD301 can be programmed to pass the I/Os AD0–AD7 through the device enabling a shared memory or peripheral resource to be accessed. Port B has an additional mode to the general port mode. The PSD301's on-chip PAD can be programmed to generate chip-select signals which can be routed to Port B's output for external chip selection as CS0–CS7. Port C can be programmed for inputs A16–A18 or as additional chip-select outputs CS8–CS10. Although labeled as address inputs, A16–A18 can be used for general Boolean inputs to the PAD array. | Figure 4 extends the option offered in Figure<br>3 to a 16-bit multiplexed bus. AD8–AD15<br>convey address and data I/O. The port<br>options remain the same as for Figure 3; thus,<br>these two configurations are suitable for<br>multiplexed address/data systems of 8 or 16<br>bits.<br>Figures 5 and 6 show options for a non-<br>multiplexed host processor or controller.<br>Figure 5 is suited to byte-wide systems and<br>Figure 6 to 16-bit word-wide configurations.<br>In Figure 5, Port A is used for data D0–D7 but<br>Port B is still available for general I/O opera-<br>tions or chip-select outputs. This configura-<br>tion is suitable for processors such as the<br>M68008.<br>The function of Port C is the same in all of the<br>four modes of operation. For 16-bit data<br>transfers, an additional 8 bits of data is<br>required. Figure 6 shows Port B as the data<br>bus for the higher-order data byte D8–D15.<br>With D0–D7, this configuration is suitable for<br>16-bit microprocessors such as the M68000.<br>Port C is available for address inputs or chip-<br>select outputs. |



**PSD3XX** 



### **Address Inputs**

inputs: AD0-AD15. The device can be programmed to accept either address inputs or multiplexed address/data inputs. The address lines can be latched into the one or two octal latches for multiplexed byte or wordwide buses respectively. The device is initially programmed with a word configuration setting the PSD3XX to a specific mode; for example, one configuration bit selects whether the address input is multiplexed with data or is a non-multiplexed dedicated address. In the non-multiplexed scheme, the input latches are held as transparent. When the address inputs are valid on the chip as A0-A15, they can be subdivided into two buses: as lower-order addresses (A1-A11), and as higher-order addresses (A12-A15). A1-A11 go directly to the EPROM and inputs A1-A10 go to the SRAM (see Figure 2). The EPROM blocks are selected through the PAD via outputs ES0--ES7 as shown in Figure 2; and the SRAM is selected by the RS0 output.

The processor interface has 16 address

The address input lines A11–A15, along with possible additional address inputs A16–A19, go into the PAD array. These address inputs are available for mapping the blocks of memory into the map scheme of the system. One option is to program the additional address inputs as valid higher-order address inputs for memory addressing ranges above 64K bytes or 32K words. If A16–A18 are not required, these PAD inputs can be ignored. Only microprocessors and microcontrollers with a large address lines. A second option is to disregard these address inputs to the chip in favor of additional chip-select outputs. A third option is available if the designer does not need additional chip-select outputs or high-order address inputs. The inputs A16–A18 can be used as general-purpose logic inputs. Examples of this are illustrated in some of the following applications.

An interface with the Z80B microprocessor uses inputs A16, A17, and A18 for signals M1, MREQ, and IORQ, respectively. In the M68008 application, two of these pins are programmed as DTACK and BERR from the PSD301 to the M68008. A wired-OR function can be implemented on the DTACK or BERR input if the user takes advantage of Port B's open-drain feature. If two PSD3XX devices are used together, the DTACK and BERR lines can be wired together and the external pull-up resistors can be used to tie these lines нідн. It is also possible to use the internal PAD of one PSD3XX to gate these lines together and produce composite DTACK and BERR inputs to the M68008.

Internally, the memory blocks are arranged word-wide with a byte-wide isolation buffer separating the lower and upper bytes. This buffer is controlled from the configuration section of the PSD3XX. When the PSD3XX is configured to operate in word-wide mode, this buffer isolates the two buses into D0–D7 and D8–D15. In word-wide mode, the control of the data flow through this buffer is determined by BHE, A0, and the device's current configuration mode. Accessing byte-wide data can be thought of as accessing bytes on even and odd word boundaries or as two separate

PSD3XX

# Address Inputs (Cont.)

banks of byte-wide data. The total complement of EPROM is shown as eight banks. The chip-select outputs ES0-ES7 come from the PAD. These are programmable address and control decode signals from the PAD inputs. Figure 7 provides a detailed schematic diagram of the PAD in terms of a traditional PLD.



### PSD3XX

### *PSD3XX Programmable Array Decoder (PAD)*

The PAD is an EPROM-based reprogrammable logic fuse array with sum-of-product outputs. For Intel-type configurations, inputs to the PAD are A11-A19, ALE, RD, and WR. For Motorola type configurations, they are R/W, AS, and E. The CSI and RESET inputs are used to deselect the PAD for power-down configurations and initialization, respectively. Internal to the PSD301 are the ES0-ES7 EPROM select lines. There is one product term dedicated to each EPROM block, and a single product term (RSO) for the SRAM selection. Address and control for each EPROM bank can programmed to a resolution of a 4K word boundary and positioned anywhere in the mapping scheme of the designer's system. Similarly, the SRAM can be positioned on 2K word boundaries.

Other internal product term outputs from the PAD are the CSIOPORT, CSADIN, CSA-DOUT1, and CSADOUT2 lines. A single

product term generates the CSIOPORT signal; this provides a base address for Ports A and B. The registers relevant to these ports are addressed as a base offset (see Table 1). The CSADIN signal is used to control the input buffer in the track mode. It can be enabled to read data in a programmed address space from Port A through the PSD3XX. CSADOUT1-2 are used to control the multiplexed address and write data through the PSD3XX to the Port A pads. The address range is programmed into the PAD qualifying the address space, but CSADOUT1 is qualified by the ALE signal outside of the PAD. This automatically lets the design distinguish between address and write data. To qualify valid write data, the PSD3XX automatically includes the CSADOUT2 product term with the  $\overline{WR}$  or  $R/\overline{W}$  signal.

| a <b>ble 1.</b> 🛛 | Register Name                       | Offset From The CSIOPORT Base Address |
|-------------------|-------------------------------------|---------------------------------------|
| ort Base Address  | Pin Register of Port A              | +2 (Accessible only during Read)      |
| ffset             | Pin Register of Port B              | +3 (Accessible only during Read)      |
|                   | Direction Register Port A           | +4                                    |
|                   | Direction Register Port B           | +5                                    |
|                   | Data Register Port A                | +6                                    |
|                   | Data Register Port B                | +7 Byte Wide                          |
|                   | Pin Register of Ports A and B       | +2 (Accessible only during Read)      |
|                   | Direction Register of Ports A and B | +4                                    |
|                   | Data Register of Ports A and B      | +6                                    |

The PAD structure enables additional chipselects to be routed to the Port B output pins. The four chip-select outputs ( $\overline{CSO}-\overline{CS3}$ ) are supported by four product terms per output.  $\overline{CS4}-\overline{CS7}$  have two product terms per output. The ability to use more than one product term from a chip-select enables the mapping of additional devices to be distributed through the address space, rather than selecting memory as a block. Sacrificing Port B terminals for chip-selects could occur in systems requiring a larger EPROM, RAM, or

I/O space. Additional PSD3XX devices can be designed into a system by using the chipselect outputs from Port C or B of one master PSD3XX. This is required for addressing a space greater than 1M. Finally, the outputs of the sum-of-product terms are inverted to be consistent with active LOW chip-select inputs for additional external RAM, EPROM, peripherals, or busses. Port C has the capability of providing three additional external chipselects, each supporting one product term per output.

### Microcontroller/ Microprocessor Control Inputs

The control inputs are also programmable: WR or R/W and RD or E are used for read/ write control of the internal EPROM, RAM, and I/O capability. Other control inputs are a programmable option for Bus High Enable or Program Store Enable (BHE/PSEN) and Address Latch Enable or Address Strobe (ALE/AS). These pins are selected to suit the bus protocol of the host processor or, where not applicable, they can be ignored. The  $\overline{CSI}$ / A19 input is available either for a power-down chip-select enable or as a higher-order address input without the power-down feature. The final control input is the RESET input; this also is a programmable option. Its active polarity can be chosen to be compatible with the host system. The function of the RESET input is to clear and initialize the PSD301 at start-up. All I/Os are set up as inputs and all outputs are either in a non-active or three-state condition.

Consequently, the PSD3XX is prevented from actively driving outputs during start-up. This feature was incorporated to prevent potential bus conflicts. In Figure 2, the CSI and RESET inputs are shown also as PAD inputs. CSI is a hardwire option into the PAD that powers down the internal circuitry and is used in power-sensitive applications. Neither signal is available as a programmable option.

### Input and Output Ports

The port section comprises Port A (8 bits), Port B (8 bits), and Port C (3 bits). These support the many different I/O operations. For port expansion, Ports A and B can be configured as general I/O ports, each to convey eight bits of digital data to and from an external device. Figure 8 shows a single cell of Port A; Figure 9 shows a single cell of Port B.

Writing data to a port is similar to writing data to a RAM location. If a port is programmed as an output, data is loaded into the output register as if it were a RAM location. Although the ports are not bit addressable, individual bits can be selected as either input or output. Thus, PA0–5 can be set as data outputs while PA6 and PA7 can be configured as inputs. Any mix of I/Os is possible giving the ports additional flexibility.

The direction of data flow through the port is determined by the data direction register. This register is dynamically programmable so that the I/O direction through Ports A and B can be altered during the microcontroller program execution. The data direction register initializes with logic zeros after an active RESET and causes each port bit to be set as an input. This state of initialization guarantees that the ports are prevented from driving the output lines at start-up. If the user requires all the Port A or Port B bits to be inputs, the data direction register can be left in this default state. To enable it as an output, logic ones can be written into the data direction location.

Due to the internal design, it is possible to program Port A or Port B bit lines as inputs and still write data to the port locations. This is because both ports have on-chip latches and can hold data. These registers are hidden or buried; i.e., they exist in the port and their condition can be read back at any time. However, these outputs do not drive the output pins because the port has been enabled as an input.

To access the port as a memory mapped location, the initial selection is made through the PAD's CSIOPORT. This provides a base address from which the locations shown in Table 1 give access to the various ports or their options. The configuration support software automatically ensures that there is no conflict between an SRAM location and I/O port in the case of memory mapped peripherals. It is also possible for the PSD3XX to distinguish between I/O and memory mapped locations. The user can input memory and

### PSD3XX

# PSD3XX Device Description

### Input and Output Ports (Cont.)

I/O control signals to the PAD through the A16–A18 inputs and program an active CSIOPORT output by decoding these signals. This can be achieved with Intel- and Zilogtype processors which have separate memory and I/O controls. Signal input through pins A16–A18 is made possible through Port C. This 3-bit port is responsible for either PAD chip-select outputs or address/logic inputs. CSIOPORT points to a base address at which Ports A and B reside. Table 1 provides the offset from the base address and the associated port function. Figure 2 shows that Port A is driven by a multiplexed address/data bus of AD0–AD7 and the selection of address/data is made from the configuration memory and internal control functions.

The other options available to the user are selecting 1) the shared resource or track mode where AD0–AD7 is routed directly through to the Port A output, or 2) the latched address A0–A7. In track mode, AD0–AD7 inputs to the PSD3XX are used to access local or private memory and peripherals and the outputs AD0–AD7 through Port A are used to access a public resource.



**PSD3XX** 



### **PSD3XX** General System Configuration

The PSD3XX family devices consists of two byte-wide configurable I/O ports (Ports A and B), 256K to 1M bits of EPROM, 16K bits of RAM, and the PAD. Additional I/O capability to and from the PAD is through a 3-bit I/O (Port C). There are also on-chip latches to support processors and controllers that multiplex address and data on the same bus. The EPROM memory section of the device is programmable just like a standard EPROM device. However, unlike the single-chip EPROM, the PSD3XX must also be configured to function into one of its many possible modes of operation. This

is done by programming a non-volatile EPROM memory location with 45 configuration bits. These bits select the mode of operation and are programmed into the EPROM along with the hexadecimal microprocessor/microcontroller assembly language object code. When using MAPLE software, the assignment of logic conditions to the configuration bits locations is transparent to the user; the resultant word is merged with the EPROM code and the data map for the PAD.

### PSD3XX General System Configuration (Cont.)

Table 2 shows the the configuration locations and their functional assignment. For example, one of the configuration bits enables the device architecture to be compatible for either byte- or word-wide data buses. This is the configuration data or CDATA bit. The 256 Kbits of EPROM can be configured as a 32K byte-wide bus for applications with an 8031 microcontroller or as a 16K word-wide bus for applications with an M68000 microprocessor. These configuration bits are discussed in detail as each feature is covered in this application note.

In addition to bus width, the polarity and mode of the bus control signals are programmable. There are two types of read/write control: one is consistent with either a Motorola and Texas Instruments control bus standard: the other is consistent with the Intel/National Semiconductor/Zilog control bus standard. The configure read and write bit (CRRWR), distinguishes between one of two conventions: either an Intel (8031) or Motorola (M68HC11) convention can be selected by programming this single bit in the configuration memory. The Intel device requires the PSD3XX to be programmed with an active LOW  $\overline{RD}$  and  $\overline{WR}$  controls (CRRWR = 0). For applications with the Motorola microprocessor, select the R/W and E option (CRRWR = 1). In addition to a choice of two READ/ WRITE controls, the user can select either a multiplexed Address/Data Bus or separate address and data lines.

Figure 3 shows the configuration that is best suited for the 8031 microcontroller; Figure 4 shows the configuration for an 80196 microcontroller with a 16-bit multiplexed addressed/ data bus. For the non-multiplexed modes:

Figure 5 applies to M6809 microprocessors, while Figure 6 shows the mode applicable to the M68000. Selection of multiplexed or nonmultiplexed buses is a programmable option that can be invoked through the configure address/data multiplex (CADDRAT) bit. With the 8031 controller, address outputs A0–A7 are multiplexed with the data D0–D7 input/ output lines to create a composite AD0–AD7 bus. The PSD3XX's input latches can be programmed to catch a valid address when the microcontroller's ALE signal transitions from active HIGH to inactive LOW. The polarity of the ALE signal is also a programmable feature in the CALE field of the configuration table. Address latching can be programmed to occur on either an active HIGH or an active LOW ALE signal. With Intel devices, the address is valid when ALE is HIGH. Once latched, data or code can be read from, or written to, the PSD3XX. The CALE active HIGH or LOW ALE configuration bit only applies to addresses A0-A15. A separate configuration bit, (CADDHLT), exists for the control of the higher-order address inputs (A16-A19). If necessary, these addresses can also be latched by the host system.

The highest address input is A19 but this signal can be omitted in favor of a power-down chip-select input (CSI). A19/CSI is selected by the CA19/CSI configuration bit. When the  $\overline{\text{CSI}}$  input is selected and the pin is driven HIGH, the device can be powered-down consuming only standby power. When configured with other CMOS devices, the standby power is in the 80–250  $\mu$ A range. Many CMOS microcontrollers do not need a large memory address space; thus, address inputs A16–A19 would be unnecessary. The CA19/CSI input can be programmed with a logic LOW to enable a power-down option for power sensitive applications.

The address/data multiplexed scheme also supports the 16-bit processors. In this case, AD0–AD15 convey a 16-bit address qualified by ALE (or AS for the Motorola convention) and 16-bits of data I/O. This feature is shown in Figure 4. A microcontroller that would use this scheme is the 80C196. The M68HC11, like the 8031, uses the 8-bit multiplexed scheme but with the Motorola convention for bus control.

Another control pin used for 80C31 applications used to distinguish between program and data memory is the PSEN output. The COMB/SEP configuration bit should be programmed HIGH if data and memory are separate and LOW to configure a combined memory space in the PSD3XX. This is a

ration (Cont.)

**PSD3XX General** useful feature for systems that require program memory and data memory to be in separate blocks.

> For systems that use separate data and address buses, the address latches can be set into a transparent mode by clearing the CADDRDAT bit location. Thus, the PSD3XX is suitable for multiplexed or non-multiplexed bus structures employing 8- or 16-bit bus widths.

> The RESET input to the PSD3XX enables the device to be initialized at start-up. RESET

can be either active HIGH or active LOW depending on the processor type. The CRESET configuration bit selects the polarity of the RESET input: LOW for active LOW and HIGH for active HIGH RESET. Normally, memory systems do not require a RESET input; however, the PSD3XX contains data direction registers for the ports that must be initialized at start-up. Note that all port I/O buffers are automatically programmed as inputs during start-up.

| Table 2.<br>Non-volatile | Configuration<br>Bits | Number of Bits | Function                                                                                                              |
|--------------------------|-----------------------|----------------|-----------------------------------------------------------------------------------------------------------------------|
| Configuration            | CDATA                 | 1              | CDATA . 0 = eight bits, 1 = sixteen bits                                                                              |
| Bits                     | CADDRAT               | 1              | ADDRESS/DATA Multiplexed. 0 = Non-multiplexed,<br>1 = Multiplexed                                                     |
|                          | CRRWR                 | 1              | CRRWR. 0 = $\overline{RD}$ and $\overline{WR}$ , 1 = R/W and E                                                        |
|                          | CA19/CSI              | 1              | A19 or $\overline{CSI}$ . 0 = Enable power-down, 1 = Enable A19                                                       |
|                          | CALE                  | 1              | ALE Polarity. 0 = Active HIGH,1 = Active LOW                                                                          |
|                          | CRESET                | 1              | CRESET. 0 = Active LOW RESET, 1 = Active HIGH RESET                                                                   |
|                          | COMB/SEP              | 1              | Combined or Separate Address Space for SRAM and EPROM. $0 = $ Combined, $1 = $ Separate                               |
|                          | CPAF2                 | 1              | Port A Track Mode or Port Mode. 0 = Port or Address,<br>1 = AD0-AD7 Track Mode                                        |
|                          | CPAF1                 | 8              | Port A I/O or A0–A7. 0 = Port A pin is I/O,<br>1 = Port A pin is Address                                              |
|                          | CPBF                  | 8              | Port B I/O or CS. $0 = Port B$ pins are CSi (i = 0–7),<br>1 = Port B pins are I/O                                     |
|                          | CPCF                  | 3              | Port C A16–A18 or $\overline{CS8}$ – $\overline{CS10}$ . 0 = Port C pins are Address, 1 = Port C pins are Chip-select |
|                          | CPACOD                | 8              | Port A CMOS or Open Drain. 0 = CMOS drivers,<br>1 = Open Drain                                                        |
|                          | CPBCOD                | 8              | Port B CMOS or Open Drain. 0 = CMOS Drivers,<br>1 = Open Drain                                                        |
|                          | CADDHLT               | 1              | A16–A18 Transparent or Latched. 1 = Address latched,<br>0 = Address transparent                                       |
|                          | CSECURITY             | 1              | CSECURITY On/Off. 0 = Off, 1 = On                                                                                     |

### PSD3XX Configuration for Port Reconstruction

A key feature of the PSD3XX is the concept of port reconstruction. When using microcontrollers with additional off-chip memory, port I/O address lines are sacrificed for address, data, and memory control lines. With a multiplexed address/data scheme, two 8-bit controller ports could be lost to address and

### *PSD3XX Configuration for Port Reconstruction (Cont.)*

data. Furthermore, in some control applications, many port I/O bits are required to send actuating signals to solenoids, instrument displays, etc., and receive data through sensors and switch panels. In many control environments, a large amount of I/O capability is required; also, additional external memory is needed for microcontroller instructions to perform data manipulation. Without the PSD3XX, the supplement of extra ports as discrete latches addressed through logic decoders can add a number of chips to the final design. By using the PSD3XX, additional EPROM, RAM, and ports are all provided on one chip. Port reconstruction lets the designer reclaim the two ports sacrificed for the microcontroller's address and data.

Port configuration is achieved through the configuration register bits. CPAF1 configuration of Port A contains eight bits; programming a logic LOW assigns the selected bit with I/O capability as if it were a conventional port. If programmed HIGH, the internally latched address inputs A0-A7 are routed to Port A lines PA0-PA7. This feature enables other on-card peripherals to use A0-A7 as latched addresses. Without this feature, external peripherals to the PSD3XX would require an external octal latch to catch the multiplexed address when it becomes valid at the microcontroller's output. Configuration of Port A as general I/O or address/data is on a bit-wise basis; thus, the choice of port or address/data assignment can be mixed. For example, configuration code 11100000B programmed into location CPAF1 passes addresses A0-A2 to outputs PA0-PA2 and enables PA3-PA7 as conventional port lines.

Configuration bit CPAF2 is a 1-bit location. When programmed LOW, it selects the port/ address option, as described above. If CPAF2 is programmed HIGH, port bits PA0–PA7 are set into track mode. Activity on the PA0–PA7 outputs follow logic transitions on inputs AD0–AD7. The multiplexed address/ data input is tracked through PA0–PA7. Track mode enables the host microcontroller to access a shared memory and peripheral resource through the PSD3XX while maintaining the ability to access its own (private) memory/peripheral resource directly from the microcontroller's address/data outputs. In this mode, the address/data AD0–AD7 passes through the PSD3XX logically unaltered. In summary, PA0–PA7 can be programmed as port I/O or latched address outputs A0–A7 (each bit being programmed on an individual basis), or as AD0–AD7 outputs (track mode).

Port B bits PB0-PB7 can be programmed either as regular port I/Os, or as chip-select outputs CS0-CS7 encoded from the PAD outputs. Figure 7 shows the PAD structure as a conventional PLD. Eight bits are programmed into CPBF. Logic Low indicates that a port pin is a chip-select output derived from the PAD. Programming a logic HIGH sets the appropriate pin as an I/O function. The bit pattern 11111000B programmed into the CPBF location sets up PB0-PB4 as I/O ports and PB5-PB7 as chip-selects. The typical applications, where Port B is programmed as bi-directional, would be with microcontroller chips that need additional port bits. This would be in applications where port reconstruction is needed to drive many indicators, solenoids, read switches, sensors, etc. In large microprocessor-based systems, the chip-select option would probably be chosen; in this case, the PAD outputs select other PSD devices, DRAM memory chips, and peripherals such as timers, UARTs, etc.

The three bits comprising Port C can be programmed by the CPCF configuration bits. This group of three bits define whether Port C is used for inputs (typically A16-A18) or whether the pins are used as chip-select outputs from the PAD. Although labeled as A16–A18, the nomenclature of these pins does not constrain the designer to using these inputs as dedicated higher-order address inputs. In fact, they can be generalpurpose inputs to the PAD for processors that do not have an address capability above 64K locations. When the PSD3XX is used with the Z80B microprocessor, the Port C inputs have been programmed as  $\overline{\text{MREQ}}$ ,  $\overline{\text{IORQ}}$ , and  $\overline{\text{M1}}$ . In the case of an interface to the M6809B, two inputs of Port C have been converted to chipselect outputs for other memory devices and one output has been used to feedback a READY input to the M6809B. Port C can be used as a general I/O from the PAD in the form of address, control, and chip-select bits. A logic LOW programs a port bit as an input; a HIGH programs it as an output.

### **Chapter 2** Applications

### 8-Bit Microcontroller to PSD3XX Interface

Figure 10 illustrates the minimum configuration of one controller and one PSD3XX. The application illustrates port reconstruction through the device's Port A and Port B I/O, reconstituting port 2 and port 0 of the microcontroller. Table 3 gives the configuration information that would be programmed in the configuration section of the PSD. Table 3 shows that both port I/Os have been programmed with CMOS load and drive characteristics. A feature of the 8051/8031 family is the <u>PSEN</u> signal, which determines whether the memory selection is active for executable code or data. This family of controllers has separate memory locations for code and data. To maintain full compatibility, the PSD3XX is also capable of being programmed to respond to the PSEN signal. When A16–A18 are programmed as inputs but not driven, they should be tied active HIGH or LOW. Unused inputs to the PSD3XX must not be permitted to float. Tying can be avoided on unused A16–A18 lines if these are programmed as 'dummy' CS8–CS10 outputs. A19/CSI cannot be programmed as an output; thus, it must be tied if not used.

Table 3. Small Controller System with One 80C31 and One PSD3XX

| Configuration | Bits | Function                                     |  |
|---------------|------|----------------------------------------------|--|
| CDATA         | 0    | 8-bit data bus                               |  |
| CADDRDAT      | 1    | Multiplexed address/data                     |  |
| CRRWR         | Ó    | Set $\overline{RD}$ and $\overline{WR}$ mode |  |
| CA19/CSI      | 0    | Set CSI input power-down mode                |  |
| CALE          | 0    | Active HIGH ALE                              |  |
| CRESET        | 1    | Active HIGH RESET                            |  |
| COMB/SEP      | 1    | Code and data memory separate                |  |
| CPAF2         | 0    | Input/Output Port A                          |  |
| CPAF1         | 00H  | Input/Output Port A (0–7)                    |  |
| CPBF          | FFH  | Input/Output Port B                          |  |
| CPCF          | 000B | Port C programmed for inputs                 |  |
| CPACOD        | 00H  | Configure CMOS outputs Port A                |  |
| CPBCOD        | 00H  | Configure CMOS outputs Port B                |  |
| CADDHLT       | 0    | Transparent inputs A16–A19                   |  |
| CSECURITY     | 0    | No security                                  |  |

### Figure 10. 80C31/PSD3XX Applications



May, 1993

320

### **PSD3XX** Device Description

### *Two PSD3XX Byte-Wide Interfaces to the Intel 80C31*

Figure 11 illustrates an extension to the previous design in that two PSD3XX devices have been used, doubling the memory and port resources of the system solution. In this application, the power-down capability has been used so that one PSD3XX can be active while the other device is in power-down mode. The mean power consumption is reduced, so this configuration can be considered for power-sensitive applications.

The configuration Table 4 indicates that Port C has been configured as outputs. Provided one PSD3XX is powered up for the whole address range, its PAD can decode an address range to select and deselect the second PSD3XX device through the CS10 output. In Figure 11, the PAD output A18/CS10 on PSD3XX U2 can be used to powerdown the second PSD3XX through the A19/CSI input.

Table 4.80C31 Interfaceto Two PSD3XXDevices withPower EconomyFeature

| Configuration | Bits | Function                         |  |
|---------------|------|----------------------------------|--|
| CDATA         | 0    | 8-bit data bus                   |  |
| CADDRDAT      | 1    | Multiplexed address/data         |  |
| CRRWR         | 0    | Set RD and WR mode               |  |
| CA19/CSI      | 0    | Set CSI input power-down mode    |  |
| CALE          | 0    | Active HIGH ALE                  |  |
| CRESET        | 1    | Active HIGH RESET                |  |
| COMB/SEP      | 1    | Code and data memory separate    |  |
| CPAF2         | 0    | Input/Output Port A              |  |
| CPAF1         | 00H  | Input/Output Port A (0–7)        |  |
| CPBF          | FFH  | Input/Output Port B              |  |
| CPCF          | 111B | Outputs CS8–CS10                 |  |
| CPACOD        | оон  | Configure CMOS outputs Port A    |  |
| CPBCOD        | 00H  | Configure CMOS outputs Port B    |  |
| CADDHLT       | x    | "Don't care" for latched A16-A19 |  |
| CSECURITY     | 0    | No security                      |  |

It is not recommended that the two PSD3XX devices select each other because the PAD section of a PSD device is powered down with the rest of the device. At least one PAD decoder must be kept active to select and deselect others. Port C outputs CS16–CS18 can power-down as many as three other PSD3XX devices.



### Application Note 011

# PSD3XX Device Description

### **PSD3XX**





May, 1993

### Byte-Wide Interface

PSD3XX M68HC11 Figure 12 illustrates the configuration of an M68HC11 microcontroller which also uses the 8-bits wide multiplexed address/data bus. The application is similar to that given in Figures 6 and 7 except that the  $R/\overline{W}$  and E control lines have been invoked to establish compatibility with the Motorola device. The address strobe output from the M68HC11 is HIGH so the AS(ALE) input is set HIGH. The SRAM and EPROM section are programmed as combined and both Ports A and B are enabled as I/Os with CMOS drives. Port C is programmed with chip-select outputs CS8-CS10. Other PSD3XX devices can be mapped into the addressing scheme or the lines can be programmed to transition as strobes in defined mapping areas. The latch enable bit for the higher-order address lines A16-A19 is not used establishing a don't care condition. The CADDHLT condition must be selected if any one of A16-A19 lines is selected as input to the PSD.

In this design, the security bit is programmed. This bit prevents the reading of the PAD configuration by an unauthorized user. Furthermore, if the security bit has been programmed, standard programming machines can not read the internal code of a PSD3XX. However, data can always be read from the EPROM, RAM, and ports. This provides normal use of the device. If the address map in the PAD cannot be interpreted, the actual location of data within the address and I/O space is difficult to determine. Besides programming the CSECU-RITY bit, added security can be applied by scrambling the sequence of address and data inputs. A short PASCAL or 'C' program can be written to reorganize the original Intel MCS code to be aligned with the scrambled pins. Table 5 indicates the configuration for the M68HC11/PSD3XX interface.

| Table 5.         | Configuration | Bits | Function                      |
|------------------|---------------|------|-------------------------------|
| M68HC11 to       | CDATA         | 0    | 8-bit data bus                |
| PSD3XX Interface | CADDRDAT      | 1    | Multiplexed address/data      |
|                  | CRRWR         | 1    | Set R/W and E mode            |
|                  | CA19/CSI      | 0    | Enable CSI input              |
|                  | CALE          | 0    | Active HIGH AS (ALE)          |
|                  | CRESET        | 0    | Active LOW RESET              |
|                  | COMB/SEP      | 0    | Combined memory mode          |
|                  | CPAF2         | 0    | Input/Output Port A           |
|                  | CPAF1         | оон  | Input/Output Port A           |
|                  | CPBF          | FFH  | Input/Output Port B           |
|                  | CPCF          | 111B | Output CS8-CS10               |
|                  | CPACOD        | оон  | CMOS drivers                  |
|                  | CPBCOD        | оон  | CMOS drivers                  |
|                  | CADDHLT       | x    | "Don't care" A16–A19 not used |
|                  | CSECURITY     | 1    | Security on                   |

### **PSD3XX**

### Figure 12. 68HC11/PSD3XX Applications



May, 1993

### PSD3XX Device Description

### 8-BIT Non-Multiplexed PSD3XX Interface to M68008

Figure 13 illustrates an application in which the address and data are not multiplexed. The M68008 has an 8-bit data bus and 20-bit address bus. The PSD3XX can be programmed to support the microprocessor by providing data I/O through Port A. The address lines from the microprocessor go to inputs A0-A19. Port B outputs are used for external chip-selects to other MAP devices or other memory resources. The configuration has been set for compatibility with Motorola control signals. There are six chip-select outputs (CSO-CS5) and an address decode for DTACK and BERR. The PAD decodes an address range which is fed back to the microprocessor through these inputs. Using the open-drain configuration has been implemented in Port B bits 6 and 7. The two pullup resistors enable external memory and peripherals to access the DTACK and BERR inputs as a wired-OR function.

needed to avoid possible bus contention on these lines. In this application, ALE(AS) can be used as a general-purpose logic input to the PAD because the function of ALE becomes redundant in a non-multiplexed address/data bus. Also shown in Figure 13 is a method of inverting the active LOW DS (Data Strobe) M68008 output. The A19 input is enabled to the PSD internal PAD and inverted at the output of CS10 to drive the PSD3XX E input. The E input must be active HIGH but DS is active LOW and gualifies a valid data transfer. Thus, the PAD must perform a signal inversion. The E signal output from the M68008 is used to interface to Motorola 8-bit peripherals. However, with Motorola microcontroller families such as the M68HC11, the E signal output can drive the E input to the PSD3XX. Table 6 gives the configuration information associated with the design given in Figure 13.

If other PSD3XX devices are mapped into the M68008 system, no additional glue logic is

| Table 6.         | Configuration | Bits | Function                                        |
|------------------|---------------|------|-------------------------------------------------|
| M68008 to        | CDATA         | 0    | 8-bit data bus                                  |
| PSD3XX Interface | CADDRDAT      | 0    | Non-multiplexed address/data                    |
|                  | CRRWR         | 1    | Set R/W and E mode                              |
|                  | CA19/CSI      | 1    | Enable A19 input <sup>1</sup>                   |
|                  | CALE          | х    | "Don't care" non-multiplexed mode               |
|                  | CRESET        | 0    | Active LOW RESET                                |
|                  | COMB/SEP      | 0    | Combined memory mode                            |
|                  | CPAF2         | х    | "Don't care" Port A used for data               |
|                  | CPAF1         | ххн  | "Don't care" Port A used for data               |
|                  | CPBF          | 00H  | Port B used for chip-selects                    |
|                  | CPCF          | 001B | Configure A16 and A17 In, CS10 Out <sup>2</sup> |
|                  | CPACOD        | 00H  | CMOS drivers                                    |
|                  | CPBCOD        | 3FH  | CMOS drivers, PB6, PB7 open drain               |
|                  | CADDHLT       | 0    | Address latch transparent A16–A19               |
|                  | CSECURITY     | 1    | Security on                                     |

1. The  $\overline{\text{DS}}$  output from the M68008 drives the A19 input to the PSD3XX.

2. The internal PAD of the PSD3XX inverts the DS input to drive its own E input from the CS10 PAD output. A16 and A17 are programmed as PSD inputs.

### Figure 13. M68008/PSD3XX Applications



May, 1993

326

### 16-Bit Non-AMultiplexedFAddress/DataFPSD3XX InterfaceFto M68000F

An extension to the design is shown in Figure 14, with the configuration information shown in Table 7. The M68000 interface to the PSD3XX has a 16-bit data bus. Both Ports A and B are used to convey data. The generation of an E input to the PSD3XX has been extended from the signal inversion shown in Figure 13. The M68000 has two data strobe signals (LDS and UDS), to qualify the lower and upper bytes of a 16-bit word. The LDS and UDS lines drive the A18 and A19 inputs and are gated to provide the correct logic condition into the M68000.

| Table 7.                |
|-------------------------|
| M68000 Micro-           |
| processor to one        |
| <b>PSD3XX</b> Interface |

| Configuration | Bits | Function                                  |  |
|---------------|------|-------------------------------------------|--|
| CDATA         | 1    | 16-bit data bus                           |  |
| CADDRDAT      | 0    | Non-multiplexed address/data              |  |
| CRRWR         | 1    | Set $R/\overline{W}$ and E control inputs |  |
| CA19/CSI      | 1    | Enable A19 input                          |  |
| CALE          | x    | ALE polarity set at "don't care"          |  |
| CRESET        | 0    | Active LOW RESET                          |  |
| COMB/SEP      | 0    | Combined memory mode                      |  |
| CPAF2         | х    | "Don't care" Port A                       |  |
| CPAF1         | XX   | "Don't care" Port A                       |  |
| CPBF          | х    | "Don't care" Port B                       |  |
| CPCF          | 110B | Enable A16 and A17 Out, A18 In1           |  |
| CPACOD        | 00H  | Configure CMOS buffers Port A             |  |
| CPBCOD        | 00H  | Configure CMOS buffers Port B             |  |
| CADDHLT       | 0    | Transparent A16–A19                       |  |
| CSECURITY     | 0    | Security off                              |  |

1. Outputs UDS and LDS drive the A18 and A19 inputs of the PAD and are gated internally to give a valid E input signal to the M68000 from the CS9 output. DTACK comes from the CS8 output.

This application takes advantage of the AS input which is redundant as a latch control input in a non-multiplexed system; however, it can be used as general-purpose logic input to the PAD.  $\overline{\text{CS9}}$  and  $\overline{\text{CS8}}$  are used as output signals to the M68000's DTACK and BERR inputs.

### **Application Note 011**

# **PSD3XX** Device Description

### Figure 14. M68000/PSD3XX Applications



May, 1993

328

### *M68000/ 2X PSD3XX Applications*

With the circuit design given in Figure 15, two PSD3XX devices are used in a byte-wide mode. One PSD stores the upper data byte and one the lower data byte of a 16-bit word. By using the devices in this way, two 6-bit wide ports can be created in Port B of each device. PB6 and PB7 are programmed as open-drain outputs and wired-OR giving composite DTACK and BERR feedback signals to the M68000. The generation of the E signal for both PSD devices is achieved in the same way it was in the M68008. The LDS and UDS inputs (to U2 and U3 respectively) are inverted by the PAD and drive the relevant E inputs. Table 8 gives the configuration information relevant to both PSD devices.

### Table 8.M68000 Micro-processor to TwoPSD3XX Devicesin Parallel

| Configuration | Bits | Function                                  |  |
|---------------|------|-------------------------------------------|--|
| CDATA         | 0    | 8-bit data bus                            |  |
| CADDRDAT      | 0    | Non-multiplexed address/data              |  |
| CRRWR         | 1    | Set $R/\overline{W}$ and E control inputs |  |
| CA19/CSI      | 1    | Enable A19 input <sup>1</sup>             |  |
| CALE          | X    | "Don't care" not used                     |  |
| CRESET        | 0    | Active LOW RESET                          |  |
| COMB/SEP      | 0    | Combined memory mode                      |  |
| CPAF2         | X    | "Don't care" Port A used for data         |  |
| CPAF1         | ххн  | "Don't care" Port A used for data         |  |
| CPBF          | FFH  | Port B used for I/O                       |  |
| CPCF          | 111B | Configure CS8–CS10 <sup>2</sup>           |  |
| CPACOD        | 00H  | CMOS drivers                              |  |
| CPBCOD        | 00Н  | CMOS drivers                              |  |
| CADDHLT       | 0    | Transparent A19                           |  |
| CSECURITY     | 0    | No security                               |  |

1. A19 input to the PSD3XX's is used to receive UDS and LDS from the M68000 microprocessor. These signals are inverted by the PAD of each PSD3XX and fed back to the E input of each divice.

2. CS10 of each PSD3XX drives the inverted UDS and LDS back to E input. Port C is programmed to output CS8 and CS9. Additional byte-wide peripherals can be configured to the system and selected by these signals.

# PSD3XX Device Description

### Figure 15. M68000/ 2X PSD3XX Applications



330

.

May, 1993

### **PSD3XX** Device Description

### *16- Bit Address/ Data PSD3XX Interface to Intel 80186*

Figure 16 and Table 9 give the configuration of the PSD3XX in an Intel 80186 system. This device has a 16-bit multiplexed address/data bus. Ports A and B are used for data I/O functions, so this design can take advantage of the port expansion capability. To distinguish between memory and I/O functions, it is necessary to decode the S2 output from the 80186. This output line goes directly to the PAD through Port C bit zero. When LOW, this signal qualifies a memory access; when HIGH, it indicates that an I/O operation is in progress. Programming the PAD can use this input to differentiate between I/O and memory access.

Two additional signals from the 80186 are  $\overline{UCS}$  and  $\overline{LCS}$  (upper chip-select and lower

chip-select, respectively). The signals have been included in the system to help minimize the requirement for additional glue logic. Both can be used in the PAD decoder to position sections of EPROM and RAM. The UCS is designed to decode addresses FFFFFH to a programmable limit. The 80186 begins executing from memory location FFF0H after a system reset; thus, this signal should be used to select EPROM that contain a system initialization sequence. The  $\overline{LCS}$  has been designed to program from 00000H up to a programmable limit. In this example, the RESET line from the 80186 is active HIGH and drives the RESET input of the PSD301 which is programmed to respond to a HIGH level.

| Table 9.        | Configuration | Bits | Function                 |
|-----------------|---------------|------|--------------------------|
| Intel 80186 to  | CDATA         | 1    | 16-bit data bus          |
| PSD3XX Configu- | CADDRDAT      | 1    | Multiplexed address/data |
| ration for CMOS | CRRWR         | 1    | Set RD and WR mode       |
| Ports           | CA19/CSI      | 1    | CSI input to PAD         |
|                 | CALE          | x    | Active HIGH ALE          |
|                 | CRESET        | 0    | Active LOW RESET         |
|                 | COMB/SEP      | 0    | Combined memory mode     |
|                 | CPAF2         | x    | I/O Port A               |
|                 | CPAF1         | ххн  | I/O Port A               |
|                 | CPBF          | FFH  | I/O Port B               |
|                 | CPCF          | 000B | Input A16–A18            |
|                 | CPACOD        | оон  | CMOS drivers             |
|                 | CPBCOD        | 00H  | CMOS drivers             |
|                 | CADDHLT       | 0    | Latched A16–A19          |
|                 | CSECURITY     | 0    | No security              |

# **PSD3XX** Device Description

### Figure 16. Intel 80186/ PSD3XX Applications



May, 1993

### *16-Bit Address/ Data PSD3XX to Intel 80196 Interface*

In Figure 17, the PSD3XX is connected to an Intel 80196 microcontroller. In many microcontroller applications it is necessary to illuminate indicators (such as LEDs). Here, the PSD3XX is used to drive LED indicator

displays. High-efficiency LEDs can be illuminated through the open drain outputs of Port B. The configuration information in Table 10 indicates that Port B has open drain drivers to sink LED illumination current.

### *Table 10. Intel 80196 to PSD3XX Configuration for LED Drivers*

|     | Configuration | Bits | Function                 |  |
|-----|---------------|------|--------------------------|--|
|     | CDATA         | 1    | 16-bit data bus          |  |
| ju- | CADDRDAT      | 1    | Multiplexed address/data |  |
|     | CRRWR         | 0    | Set RD and WR mode       |  |
|     | CA19/CSI      | x    | "Don't care" A19/CSI     |  |
|     | CALE          | 0    | Active HIGH ALE          |  |
|     | CRESET        | 0    | Active LOW RESET         |  |
|     | COMB/SEP      | 0    | Combined memory mode     |  |
|     | CPAF2         | 0    | I/O Port A               |  |
|     | CPAF1         | 00H  | I/O Port A               |  |
|     | CPBF          | FFH  | I/O Port B               |  |
|     | CPCF          | 000B | Output A16–A18           |  |
|     | CPACOD        | 00H  | CMOS drivers             |  |
|     | CPBCOD        | FFH  | Open drain drivers       |  |
|     | CADDHLT       | х    | "Don't care" (not used)  |  |
|     | CSECURITY     | 0    | No security              |  |

### Interfacing the PSD3XX to 8-Bit Microprocessors Z80 and M6809 Applications

Figures 18 and 19 illustrate the PSD3XX used with 8-bit microprocessors, such as the Z80B and M6809B. Tables 11 and 12 reflect the configuration of each design, respectively. The mode of operation is 8-bit data bus with a non-multiplexed address/data input. In the case of the Z80B, <u>CS8–CS10</u> inputs are tied to M1, MREQ, and <u>IORQ</u> respectively. Since the PAD can be programmed to distinguish between memory and I/O operations, the Z80B system has access to an 8-bit data port Port B. With the M6809B system, CS8 is used to respond to the MRDY input of the microprocessor and CS9 and CS10 are available for external chip-select.



May, 1993

334

Application Note 011

Philips Semiconductors Microcontroller Peripherals

### **PSD3XX**

| Table 11.        | Configuration | Bits | Function                          |
|------------------|---------------|------|-----------------------------------|
| Z80B to PSD3XX   | CDATA         | 0    | 8-bit data bus                    |
| <i>Interface</i> | CADDRDAT      | 0    | Non-multiplexed address/data      |
|                  | CRRWR         | о    | Set RD and WR mode                |
|                  | CA19/CSI      | 0    | CSI input                         |
|                  | CALE          | x    | "Don't care" (not used)           |
|                  | CRESET        | 0    | Active LOW RESET                  |
|                  | COMB/SEP      | 0    | Combined memory mode              |
|                  | CPAF2         | x    | "Don't care" Port A used for data |
|                  | CPAF1         | ххн  | "Don't care" Port A used for data |
|                  | CPBF          | FFH  | I/O Port B                        |
|                  | CPCF          | 000B | Configure A16-A18 as inputs       |
|                  | CPACOD        | 00H  | CMOS drivers                      |
|                  | CPBCOD        | оон  | CMOS drivers                      |
|                  | CADDHLT       | 0    | A16-A18 transparent <sup>1</sup>  |
|                  | CSECURITY     | 0    | No security                       |

1. A16–A18 inputs are used as M1, MREQ, and IORQ inputs to the PAD from the Z80B output. Use the ALIAS command in the support software.

| Table 12.        | Configuration | Bits | Function                          |
|------------------|---------------|------|-----------------------------------|
| M6809 to PSD3XX  | CDATA         | 0    | 8-bit data bus                    |
| <i>Interface</i> | CADDRDAT      | 0    | Non-multiplexed address/data      |
|                  | CRRWR         | 1    | Set R/W and E mode                |
|                  | CA19/CSI      | 0    | Enable CSI input                  |
|                  | CALE          | X    | "Don't care" non-multiplexed mode |
|                  | CRESET        | 0    | Active LOW RESET                  |
|                  | COMB/SEP      | 0    | Combined memory mode              |
|                  | CPAF2         | x    | "Don't care" Port A used for data |
|                  | CPAF1         | ххн  | "Don't care" Port A used for data |
|                  | CPBF          | FFH  | Port B used for I/O               |
|                  | CPCF          | 111B | CS8–CS10 outputs                  |
|                  | CPACOD        | 00Н  | CMOS drivers                      |
|                  | CPBCOD        | оон  | CMOS drivers                      |
|                  | CADDHLT       | 0    | "Don't care"                      |
|                  | CSECURITY     | 0    | No security                       |

### Application Note 011

# **PSD3XX** Device Description

### Figure 18 Z80B/PSD3XX Applications



May, 1993

336

# **PSD3XX** Device Description

### Figure 19 6809/PSD3XX Applications



May, 1993

### PSD3XX Device Description

### *PSD3XX Interface to the Intel 80286*

Figure 20 provides a schematic of the PSD3XX interface to an 80286. The device is configured for a 16-bit data bus in the nonmultiplexed mode. Ports A and B are converted automatically for use as a bi-directional data path into the PSD3XX. (This was also the case for the M68000 microprocessor). To eliminate (or lessen) glue logic,  $\overline{CS1}$  and  $\overline{CS2}$  are generated from the internal PAD. This is programmed as an address decoder. Table 13 provides configuration information relevant to this system design.

| Table 13.        | Configuration | Bits | Function                          |
|------------------|---------------|------|-----------------------------------|
| Intel 80286 to   | CDATA         | 1    | 16-bit data bus                   |
| PSD3XX Interface | CADDRDAT      | 0    | Non-multiplexed address/data      |
|                  | CRRWR         | 0    | Set RD and WR control inputs      |
|                  | CA19/CSI      | 1    | Enable A19 input                  |
|                  | CALE          | x    | "Don't care" non-multiplexed mode |
|                  | CRESET        | 1    | Active HIGH RESET                 |
|                  | COMB/SEP      | 0    | Combined memory mode              |
|                  | CPAF2         | x    | "Don't care" Port A used for data |
|                  | CPAF1         | ххн  | "Don't care" Port A used for data |
|                  | CPBF          | ххн  | "Don't care" Port B used for data |
|                  | CPCF          | 011B | A16 input; CS9 and CS10 outputs   |
|                  | CPACOD        | оон  | CMOS drivers                      |
|                  | CPBCOD        | оон  | CMOS drivers                      |
|                  | CADDHLT       | 0    | Transparent A16–A19 input         |
|                  | CSECURITY     | 0    | No security                       |

# **PSD3XX** Device Description

### Figure 20 Intel 80286/ PSD3XX Applications



May, 1993

### **External** The of the use

Peripherals to the interest of the interest of

The configuration in Figure 21 illustrates how the user can feed address outputs from the internal latch to Port A. Addresses A0-A7, derived from a multiplexed address/data bus, can go directly to an additional peripheral without the need for an additional octal latch such as the 74HC373 or 74HC573. Port A can be used for address outputs A0-A7 while PB0-PB7 can be used as chip-selects. Lines A0-A4 of the PSD3XX drive the RS1-RS5 register select inputs of the M68230. For the M68HC11, the eight bits of address and data come from its PC port PC0-PC7 (AD0-AD7) and are latched by the AS input. Configured in this mode, the PSD3XX can address and map additional peripheral chips. Port A of the PSD3XX conveys the internally latched

address outputs A0-A7 to the output and can be used to address registers in the peripheral chips while Port B outputs can place individual peripherals at peripheral or memorymapped boundaries. Thus, a number of additional chips can be selected through Port B. This effectively can increase the port density of the system design. The general I/O capability can then be extended to extra ports, timers, UARTs, serial communications channels, keyboard interface devices, CRT controllers, etc. without the need for additional glue logic. Table 14 highlights the configuration information programmed into the PSD3XX when configuring the M68HC11 to a M68230 peripheral.

| Table 14.        | Configuration | Bits | Function                        |
|------------------|---------------|------|---------------------------------|
| M68HC11/PSD3XX   | CDATA         | 0    | 8-bit data bus                  |
| to External      | CADDRDAT      | 1    | Multiplexed address/data        |
| Peripheral       | CRRWR         | 1    | Set $R/\overline{W}$ and E mode |
| M68230           | CA19/CSI      | o    | Set power-down mode             |
| <b>Interface</b> | CALE          | · 0  | Active HIGH AS                  |
|                  | CRESET        | 0    | Active LOW RESET                |
|                  | COMB/SEP      | 0    | Combined memory mode            |
|                  | CPAF2         | o    | Port A = address A0-A7          |
|                  | CPAF1         | FFH  | Port A set for address          |
|                  | CPBF          | оон  | Port B set for chip-select      |
|                  | CPCF          | 111B | Port C set for chip-select      |
|                  | CPACOD        | оон  | CMOS buffers                    |
|                  | CPBCOD        | оон  | CMOS buffers                    |
|                  | CADDHLT       | x    | "Don't care"                    |
|                  | CSECURITY     | 0    | No security                     |

### Application Note 011

# PSD3XX Device Description

### Applications M68HC11/PSD3XX Figure 21 to M68230



<u>8</u>

### **PSD3XX** Device Description

### Additional External SRAM

Figure 22 illustrates how additional SRAMs can be configured into a system. This PSD3XX configuration is not limited to external peripheral expansion; it can also be used to add additional memory without the need for external glue logic. With an 8-bit address/ data multiplexed scheme, the higher-order addresses (A8-A15) are non-multiplexed. These address lines are fed directly to the

external SRAM from the microcontroller and do not need to go through the PSD3XX These lines can drive the RAM chip directly. Thus the M68HC11 system, which is highly memory-intensive and requires more RAM than the microcontroller and PSD3XX can supply, can take advantage of the configuration shown in Figure 23 which is detailed in Table 15.

| Table 15.       | Configuration | Bits | Function                     |
|-----------------|---------------|------|------------------------------|
| M68HC11/PSD3XX  | CDATA         | 1    | 8-bit data bus               |
| Configured to   | CADDRDAT      | 0    | Multiplexed address/data     |
| Address         | CRRWR         | 1    | Set R/W and E mode           |
| Additional SRAM | CA19/CSI      | 1    | Set power-down mode          |
|                 | CALE          | 0    | Active HIGH AS               |
|                 | CRESET        | 0    | Active LOW RESET             |
|                 | COMB/SEP      | 0    | Combined memory mode         |
|                 | CPAF2         | 0    | Port A = address A0–A7       |
|                 | CPAF1         | FFH  | Port A set for address       |
|                 | CPBF          | 00H  | Port B set for chip-select   |
|                 | CPCF          | 111B | Port C set for chip-select   |
|                 | CPACOD        | 00H  | CMOS buffers                 |
|                 | CPBCOD        | 00H  | CMOS buffers                 |
|                 | CADDHLT       | х    | Latched A16–A19 "don't care" |
|                 | CSECURITY     | 0    | No security                  |

### **PSD3XX**





May, 1993

### Additional External SRAM (Cont.)

Figure 23 illustrates, and Table 16 details, a similar system using the Signetics SC80C451. This microcontroller has many ports and some SRAM but requires off-chip EPROM to store programmed instructions. This device is similar to the 8051/31 family which uses the active LOW PSEN signal to differentiate between executable code and

data. Since it is a multiplexed 8-bit machine, it can use the on-chip latches. In highly RAMintensive applications, an additional two 8K x 8 SRAM chips can be included and selected through Port B. If additional SRAM chips are not needed, Ports A and B can recreate Ports 0 and 2 which are lost in addressing external memory.

Table 16.SC80C451/PSD3XXConfigured toAddressAdditional SRAM

| Configuration | Bits | Function                     |
|---------------|------|------------------------------|
| CDATA         | 1    | 8-bit data bus               |
| CADDRDAT      | 0    | Multiplexed address/data     |
| CRRWR         | 0    | Set RD and WR mode           |
| CA19/CSI      | 0    | Set power-down mode          |
| CALE          | 0    | Active HIGH ALE              |
| CRESET        | 1    | Active HIGH RESET            |
| COMB/SEP      | 1    | Separate data/program memory |
| CPAF2         | 0    | Port A = address A0–A7       |
| CPAF1         | FFH  | Port A set for address       |
| CPBF          | 00H  | Port B set for chip-select   |
| CPCF          | 111B | Port C set for chip-select   |
| CPACOD        | 00H  | CMOS buffers                 |
| CPBCOD        | 00H  | CMOS buffers                 |
| CADDHLT       | 0    | "Don't care" (not used)      |
| CSECURITY     | 0    | No security                  |

### Figure 23. SC80C451/ PSD3XX to 16K SRAM Applications



May, 1993

345 345

### PSD3XX

### PSD3XX Used in Track Mode

Figure 24 illustrates a design that utilizes the track mode of operation that has been discussed but not illustrated in an application. Here, Port A passes or tracks through the multiplexed address and data of the 80196. Address and data outputs AD0-AD7 from the 80196 appear on the PSD3XX Port A pins. In this mode, the SRAM, shown in Figure 24 as U4, can be accessed either by the 80196 (used in byte mode) or by a second processor in the host system. The SRAM in the design can be used as a common resource. An example would be a system in which the host uses the memory to pass parameters to the local 80196. Table 17 gives the configuration data for an 80196/PSD301 interface to SRAM using Track Mode.

A Direct Memory Access can transfer data to the common memory via a BUSRQ/BUSGR handshake. Note that the PAD in the PSD3XX controls the three-state condition of the octal latch U3 74HCT373 enabling the host system to control SRAM addresses A0–A7. Port A of the PSD3XX is also put into a three-state condition during host-to-SRAM activity. In the design given in Figure 24, Port B outputs PB0, PB1, and PB2 are used to control the SRAM inputs  $\overline{CE}$ ,  $\overline{OE}$ , and  $\overline{WR}$  respectively. Also, A8, A9, and A10 are fed through the PAD as identity functions to the open drain drivers of PB3, PB4, and PB5 respectively. There is no track-through feature for these address lines; however, if they are fed through the PAD, they can drive the external memory resource as if they were tracked through.

The M80196 can operate in either byte- or word-wide mode controlled by its BUSWIDTH input. In this application, the PB6 output drives the BUSWIDTH line to switch between the byte-wide bus of the external SRAM and the word-wide interface of the PSD3XX. All Port B outputs, with the exception of PB6, are configured as open-drain. Provided the host system also has open drain/ collector drivers, both systems can access the SRAM without bus conflict. The only additional circuitry required would be the pull-up resistors.

Table 17. Intel 80196 to PSD3XX Used to Access External SRAM in Track Mode

| Configuration | Bits | Function                           |
|---------------|------|------------------------------------|
| CDATA         | 1    | 16-bit data bus                    |
| CADDRDAT      | 1    | Multiplexed address/data           |
| CRRWR         | 0    | Set RD and WR mode                 |
| CA19/CSI      | 0    | Set power-down mode                |
| CALE          | 0    | Active HIGH ALE                    |
| CRESET        | 0    | Active LOW RESET                   |
| COMB/SEP      | 0    | Separate data/program memory       |
| CPAF2         | 1    | Address/data (Track Mode)          |
| CPAF1         | ххн  | "Don't care" in Track Mode         |
| CPBF          | оон  | Port B set for chip-select outputs |
| CPCF          | 111B | Port C set for logic outputs       |
| ĊPACOD        | 00H  | CMOS buffers                       |
| CPBCOD        | FFH  | Open drain buffers                 |
| CADDHLT       | x    | Latched A16–A19 "don't care"       |
| CSECURITY     | 0    | No security                        |

### Application Note 011

### PSD3XX Device Description

### **PSD3XX**

### SRAM PSD3XX Track Intel 80196/ Mode to External Figure 24.



May, 1993

Application Note 011

PSD3XX

### **Chapter 3**

The support software for the PSD3XX family is designed to run on IBM PC XT/AT or 100% compatible systems. It is menu-driven and very user-friendly. In many cases it has the capability of preventing the user from creating invalid configurations. For example, in a non-multiplexed system with a 16-bit data bus, Ports A and B are used for data I/O. The software recognizes this and prevents the user from inadvertently programming Ports A and B as regular ports.

When running in the IBM PC environment, the PSD development software creates the menu shown in Figure 25. Initially, the designer selects the part type with the user key F8 or moves the screen cursor to PARTNAME. In the example shown, the selection for the part type is PSD301.



2402 25

The menu listed to the left of Figure 25 links the function keys and their association. F1 suspends the MAPLE software to DOS for file editing or updating. F2 exits the program and returns the user to the DOS environment. F3 selects the programmer option so the user can program the compiled object file into the PSD301 device provided a programmer is connected to the system. The LOAD selection (F5), loads an existing program into the MAPLE environment for editing and compiling. F6 saves that program under a userdefined name. F7 compiles the user-generated file into an object file that can be transferred to the programmer. F8 provides part type selection, either PSD301 or MAP168.

Figure 26 illustrates a second menu to the right of the main menu. The list shows ALIASES, CONFIGURATION, PORT C, PORT A, PORT B, and ADDRESS MAP. The designer selects each choice, starting from ALIASES, and moves down through the list configuring each option.

PSD3XX

| Figure 26.<br>MAPLE Menu<br>with PARTNAME<br>Submenu | MAP SILVER<br>MAPLE Copyright                                                    | VERSION 3.008<br>t (C) 1988, Wafer                                | Scale Integration | n, Inc. Revision 3.(                                                                      | 03B     |
|------------------------------------------------------|----------------------------------------------------------------------------------|-------------------------------------------------------------------|-------------------|-------------------------------------------------------------------------------------------|---------|
|                                                      | 1)<br>12<br>12<br>13<br>14<br>14<br>15<br>15<br>15<br>16<br>17<br>17<br>17<br>17 | 2 EXIT<br>3 MAPPRO<br>4 PARTLIST<br>5 LOAD<br>5 SAVE<br>7 COMPILE |                   | PARTNAME: PSD301<br>ALIASES<br>CONFIGURATION<br>PORT C<br>PORT A<br>PORT B<br>ADDRESS MAP |         |
|                                                      | If you want to n<br>Cursor - Up:† Dou                                            |                                                                   | s, press ⟨Enter⟩. |                                                                                           |         |
|                                                      |                                                                                  |                                                                   |                   |                                                                                           | C:\WSI  |
|                                                      |                                                                                  |                                                                   |                   |                                                                                           | 2402 26 |

### ALIASES Menu

The ALIASES selection lets the user individually define the port pins with user-relevant names. The circuit diagram shown in Figure 13 uses an M68008 processor, with BERR and DTACK signals coming from the PAD, as well as the remaining CS0, CS5 chip-select outputs.

**PSD3XX** 

### Figure 27. CONFIGURATION Menu

Figure 27 gives the CONFIGURATION menu. In this case, the PSD301 has been configured for the system shown in Figure 10: interfacing to an 80C31; the 8-bit data/address bus is multiplexed. The chip-select input is chosen over the A19 input. The RESET and ALE polarity is set as active HIGH with RD and WR control inputs enabled. The inputs A16–A19 are transparent and separate strobes are enabled for SRAM and EPROM. This feature activates the  $\overrightarrow{PSEN}$  input. In this configuration it is possible for the SRAM and EPROM to share the same address space. After the device is configured, Ports A, B, and C can be set up. If the main menu is invoked by selecting F1 (Figure 28), Port C can be selected as shown in Figure 26. Here, the individual selection of  $\overrightarrow{CS}$ /Ai configures the three pins as outputs.

| ddress/Data Mode (Multiplexed: MX, Non-Multiplexed: NM)                                                 | MX       |
|---------------------------------------------------------------------------------------------------------|----------|
| ata Bus Width (8/16 bits)<br>SI (Power-Down/Chip Enable) or A19                                         | 8<br>CSI |
| eset Polarity (Active Low: LO, Active High: HI)                                                         | HI       |
| LE Polarity (Active Low: LO, Active High: HI)                                                           | HI       |
| R and RD (WRD) or R/W and E (RWE)?                                                                      | WRD      |
| 19-A16 Transparent or Latched by ALE (Trans: T, Latched: L)                                             | T        |
| sing different READ Strobes for SRAM and EPROM ? (Y/N)<br>eparate SRAM and EPROM address spaces ? (Y/N) | Y        |
| eparate Shill and El holl address spaces : (1/h)                                                        |          |
|                                                                                                         |          |
|                                                                                                         |          |
| f SRAM and EPROM share the same Address space, press SPACEB                                             | AR.      |
|                                                                                                         |          |

# PSD3XX Device Description

# PSD3XX

| Figure 28.<br>Port C<br>Configuration<br>Menu | PORT C<br>PIN CS/Ai<br>PC0 CS8<br>PC1 CS9<br>PC2 CS10                                                                                                                                                                                           |                |
|-----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
|                                               | Configure all the 3 pins before going to any CS Definition .         If you want to configure PC0 as A16, press SPACEBAR.         F1 - Return to Main Menu       F2 - Temporary exit to F3 - Goto CS Definition         F3 - Goto CS Definition | Dos<br>C:\\#SI |
|                                               |                                                                                                                                                                                                                                                 | 2402 28        |

# Figure 29. Port A Configuration Menu, Part 1.

Figure 29 shows the configuration of Port A. This could be applied to the example shown in Figure 21 which shows the PSD301 interfacing to an M68230. Port A passes the PSD301's internally latched address lines A0–A4 directly to the M68230. PA5–PA7 are configured as port outputs and can be used as general I/Os.

|                                                                              | PIN        |          | CHOS/OD      |
|------------------------------------------------------------------------------|------------|----------|--------------|
| mfigure each pin to be Address or I/O.<br>ins configured as Addresses should | PA0<br>PA1 | A0<br>A1 | CMOS<br>CMOS |
| ormally have CMOS outputs.                                                   | PA2        | A2       | CMOS         |
|                                                                              | PA3        | A3       | CMOS         |
|                                                                              | PA4        | A4       | CMOS         |
|                                                                              | I PAS      | 10       | CMOS         |
| ) configure PAO as I/O, press SPACEBAR.                                      | PA6        | 10       | CMOS         |
| -                                                                            | PA7        | 10       | CMOS         |

C:NWSI

Application Note 011

# PSD3XX Device Description



# PSD3XX Device Description

## Figure 32. ADDRESS MAP Menu

Figure 32 shows the ADDRESS MAP menu. The designer can enter a binary code for the address range of the various select lines; ES0–ES7, RS0, and CSP, being the EPROM, SRAM, and PERIPHERAL assignments, respectively. A space for individual hexadecimal files is reserved under the FILENAME section. The Intel MCS files are listed as they would be compiled and programmed into the device.

| · •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ADDRESS MAP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| A         A         A         A           19         18         17         18         17           ES0         N         N         N         N         N           ES1         N         N         N         N         N         N           ES1         N         N         N         N         N         N         N           ES2         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N | N       0       0       1       0       N       02000       2FFF       2000       2FFF       CODE2.MCS         N       0       0       1       1       N       03000       3FFF       3000       3FFF       CDDE3.MCS         N       0       1       0       0       N       04000       4FFF       4000       4FFF       TABLE1.MCS         N       0       1       1       0       06000       6FFF       5000       5FFF       TABLE1.MCS         N       0       1       1       N       07000       7FFF       4000       4FFF         N       1       0       0       N       08000       8FFF       4000       4FFF |  |
| Fill in A19-A11 (Binary) or SEGMI START (Hex); and FILE(START, STOP)<br>and FILE NAME. Use SPACEBAR to erase any field value.<br>F1 - Return to Main Menu F2 - Temporary exit to DOS F3 - Goto Help<br>Cursor - Up:† Down:↓ Left:+ Right:→ N - Non-editable bit.<br>C:NWSI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |

After configuration has been established, the user can return to the main menu and select the COMPILE option. The configuration is compiled and converted to a JEDEC array program map.

When successfully finished, the designer can select the MAPPRO option (see Figure 25), and when a WSI MAGICPRO<sup>TM</sup> programmer

is available in the PC system, finalize the design by programming a PSD301.

The Address Map for Port B can be configured as shown in Figure 33. Per Figure 31, depress function key F3 to invoke the chip select definition. The entries can be made for logic HIGH, LOW, or "don't care" conditions.

2402 32

# **PSD3XX** Device Description

PSD3XX



#### Summary

The PSD3XX microcontroller peripheral with memory, supported with low-cost software and programming capability form WSI, greatly simplifies the overall design of microcontroller based systems. The key advantage is the extensive condensing of glue logic, latches, ports, and discrete memory elements into a single-device, enhancing the reliability of the final product. Applications for the device extend to practically any area that uses microcontrollers or microprocessors, from modems and vending machines to disc controllers and high-end processor systems. •

# The PSD301 streamlines a microcontroller-based smart transmitter design By Seyamak Keyghobad – Bailey Controls, and Karen Spesard – WSI

# **PSD301**

| Abstract                  | A smart transmitter design is described<br>which takes advantage of the integration<br>capabilities and flexibility of WSI's<br>PSD301 microcontroller peripheral. The<br>following discussion illustrates how the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | PSD301, in effect, was responsible for<br>eliminating an extra 2.5 inch diameter<br>board in a system where real estate is at<br>a premium by reducing the number of<br>components from 12 down to 5.                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction              | Designers of systems using micro-<br>controllers and microprocessors often<br>face the problem of how to integrate<br>peripheral logic and memory functions<br>into their designs without using many<br>discrete chips and large areas of board<br>space. For example, when external<br>EPROM and SRAMs are configured into<br>systems with ROMless microcontrollers,<br>general I/O ports are typically sacrificed<br>for address, data input/output, and control<br>functions. When these I/O ports are<br>depleted, the total chip count of the<br>system is increased by requiring the use<br>of additional external ports and steering<br>logic. Designers, who have limited board<br>space, such as found in the disk drive,                                                                                           | modem, cellular phone, industrial/process<br>control, and automotive industries, find<br>this a critical problem.<br>The PSD301 programmable peripheral<br>device from WSI solves this problem by<br>integrating all SRAM, EPROM, program-<br>mable decoding and configurable I/O port<br>functions needed in 8 or 16-bit micro-<br>controller designs into a single-chip<br>user-configurable solution. This is<br>illustrated in the following industrial<br>control application where the PSD301<br>eliminates seven chips and saves the<br>designer from needing another board in<br>the system.                 |
| The Design<br>Application | The smart transmitter, shown in Figure 1,<br>was developed by Bailey Controls, a<br>manufacturer of process control<br>instruments, to support a popular field<br>bus protocol. One of its functions in this<br>sensor application is to measure<br>pressure, differential pressure, and flow<br>rates through pipes in industrial<br>environments such as chemical plants, oil<br>refineries, or utility plants. A host system<br>monitors the transmitter via a process<br>control network.<br>The completed transmitter design<br>consists of three main boards. The first<br>board includes the power supply and<br>communications hardware to provide<br>power to the rest of the system and feed-<br>back to the process control network. It<br>consists of communications transformers<br>and line drivers/receivers. | The second board is the digital micro-<br>controller board and contains the 68HC11<br>microcontroller as well as the PSD301<br>programmable peripheral, a PLD, UART,<br>and LCD display. Its function is to<br>communicate and receive the inputs from<br>the third board, process the data, and<br>display the appropriate results to the LCD.<br>The third board or input board is mostly<br>analog. It receives inputs from string gauge<br>sensors which use a bridge circuit for<br>measuring pressure using a diaphragm.<br>The input board then converts the signals<br>so the microcontroller can read them. |

### The PSD301 streamlines a microcontroller-based smart transmitter design By Seyamak Keyghobad – Bailey Controls, and Karen Spesard – WSI

**PSD301** 



# Desian **Considerations**

The smart transmitter system is rather small. Its case is only 2.5 inches in diameter and thus requires boards that fit this small form factor as shown in Figure 2. Not surprisingly, the major design consideration during development was board space. This was especially true for the microcontroller/digital board where real estate is at a very high premium.

One of the problems was that there were already requirements for the 68HC11 microcontroller, a 256K EPROM, 16K SRAM, a PLD, TTL logic, a UART, and an LCD display on the digital board. This

meant extending the number of boards used beyond one unless a way could be found to integrate some of these elements.

Other important considerations, or goals actually, for the design were to reduce power consumption to less than 2.4W, improve reliability, lower design costs, and shorten the time-to-market.

To meet these objectives, Bailey Controls looked to user-configurable peripheral, the PSD301, for its integration capabilities, its flexibility, and its low power of less than 35 mA active and 90 µA typical powerdown.

#### The PSD301 streamlines a microcontroller-based smart transmitter design By Seyamak Keyghobad – Bailey Controls, and Karen Spesard – WSI

**PSD301** 

Figure 2. The Bailey Smart **Transmitter Board** Using the WSI PSD301.



# **PSD301** Architecture

The PSD301 is a field programmable device that has the ability to interface to virtually any 8- or 16-bit microcontroller without the need for external glue logic. This is possible because the PSD301 combines the elements necessary for a complete microcontroller peripheral solution, such as user-configurable logic, I/O ports, EPROM and SRAM, all into one device. The functional block diagram of the PSD301 in Figure 3 shows its main sections: the internal latches and control signals, the programmable address decoder (PAD), the memory, and the I/O ports.

The control signals and internal latches in the PSD301 were designed so interfacing to any microcontroller would be easy and require no glue logic. For instance, the PSD301 can interface directly to all multiplexed (and non-multiplexed) 8- and 16-bit microcontroller address/data buses because it has two on-chip 8-bit address latches. This means no external latches are required to interface to multiplexed buses. It also has programmable polarity on the control inputs ALE/AS and RESET, so they can be configured to be active high or active low.

The other control signals, RD/E, and WR/R/W, are also programmable as /RD and /WR or E and R/W, enabling direct interface to all Motorola- and Intel-type controllers.

The programmable array decoder (PAD) is an EPROM-based reprogrammable logic "fuse" array with 11 dedicated inputs, up to 4 general-purpose inputs, and up to 24 outputs. The PAD is used to configure the 8 EPROM blocks on 2K word boundaries and the SRAM on a 1K word boundary anywhere within a 1 Meg address space. It is also used to generate a base address for mapping ports A and B, as well as to provide mapping for the track mode. The PAD, like a traditional PLD, can generate up to eight sum-of-product outputs to extend address decoding to external peripherals or to implement logic replacement on a board.

Memory in the PSD301 is provided by EPROM for program and table storage and SRAM for scratch pad storage and development and diagnostic testing. The EPROM density is 256K bits and the SRAM density is 16K bits. Both can be operated in either word-wide or byte-wide fashion. which translates to a 32K x 8 or 16K x 16 EPROM configuration and a 2K x 8 or 1K x 16 SRAM configuration. As described above, the EPROM is divided into 8 blocks (of 4K x 8 or 2K x 16), with each block typically on a 2K boundary locatable within a 1 Meg address space.

There are 3 ports on the PSD301 that are highly flexible and programmable: Ports A, B and C, illustrated in Figure 4. Port A is an

**PSD301** 

## The PSD301 streamlines a microcontroller-based smart transmitter design By Seyamak Keyghobad – Bailey Controls, and Karen Spesard – WSI

## PSD301 Architecture (Cont.)

8-bit port that can be configured in a variety of ways. For example, if the PSD301 is in the multiplexed mode, port A can be configured pin-by-pin to be an I/O or a lower order latched address. Alternatively, port A can be configured in the track mode to transfer 8 bits of address and data inputs through port A. This enables the microcontroller to share external resources, such as additional SRAM, with other controllers. In either case, each port A output can be configured to be CMOS or open drain. If the PSD301 is in the non-multiplexed mode, port A becomes the lower order data for the chip.

Port B is another flexible 8-bit port. In the multiplexed mode or 8-bit non-multiplexed mode, each pin on port B can be customized to function as an I/O or a chip-select output. The chip-select signals are determined by the PAD programming

and are used for general logic replacement or to extend the address decoding to external peripherals. Each pin in this mode can also be programmed to have a CMOS or an open drain output. In the 16-bit non-multiplexed mode, port B becomes the higher order data for the chip.

Port C is the third port which is available on the PSD301. It is a 3-bit port that can be programmed on a pin-by-pin basis to be chip-select outputs and/or general-purpose logic inputs or addresses to the PAD. Some uses for port C might be to extend the address range to 1 Meg, or to create finer address decoding resolution down to 256. Or, one might use port C to help create a simple state machine.

# *Simple Interfaces to the PSD301.*

One of the overwhelming advantages of the PSD301 is its ability to interface to virtually any microcontroller without any glue logic, while providing additional I/O ports and memory. This is accomplished by configuring or programming the part to function in an operational mode geared for a specific application.

For instance, there are 45 configuration bits on the PSD301 that have to be programmed in addition to the EPROM prior to usage. These configuration bits are determined during development by the designer using the WSI MAPLE software package. After the configuration bits are determined, the EPROM code and configuration data can be merged during compilation and the part subsequently programmed.

Interfacing the PSD301 to different microcontrollers is accommodated by the configuration bits discussed above. To illustrate how this works, two examples are provided.

The first example is with the 80C196 microcontroller. This 16-bit microcontroller from Intel interfaces directly to the PSD301, providing it with additional off-chip program store EPROM and data store SRAM, as well as the flexibility that comes with three additional I/O ports. As illustrated in Figure 5, the 80C196's 16-bit multiplexed address/ data bus and control signals (RD,WR, BHE, ALE, RESET) connect directly to the PSD301. This is achieved with the PSD301 in the following configuration:

- 16-bit data bus
- Multiplexed address/data
- RD and WR mode set
- Active HIGH ALE
- Active LOW RESET
- □ A16 A18 configured as output
- Combined memory mode

The other configuration options that are available, but not listed above, are application dependent and can be changed to meet the requirements of the design. For instance, on pin 43 (A19/ $\overline{CSI}$ ), the powerdown option  $\overline{CSI}$  could be selected if

# The PSD301 streamlines a microcontroller-based smart transmitter design By Seyamak Keyghobad – Bailey Controls, and Karen Spesard – WSI

**PSD301** 

| Simple<br>Interfaces<br>to the PSD301<br>(Cont.) | <ul> <li>power consumption savings is important.<br/>If it isn't and another logic input to the<br/>PAD would be helpful, A19 could be<br/>selected. And, if open-drain drivers are<br/>important on one of the ports to drive a<br/>display, for example, they also could be<br/>selected instead of CMOS drivers.</li> <li>All other microcontrollers have simple<br/>interfaces to the PSD301 as well. This<br/>includes all the variations of micro-<br/>controllers in the 8-bit 68HC11 family<br/>from Motorola. For simplicity's sake, the<br/>PSD301 interface to 68HC11 versions<br/>with multiplexed address/data buses will<br/>be discussed, although the non-<br/>multiplexed versions will interface to the<br/>PSD301 in a similar manner, except in<br/>this case port A will become dedicated for<br/>8-bit data.</li> <li>Figure 6 illustrates the interconnections<br/>between the PSD301 and the 68HC11<br/>microcontroller with multiplexed<br/>address/data buses. Again, all the</li> </ul> | address/data connections are direct, as<br>well as the control signals (E, R/W, AS,<br>and /RESET). Because BHE/PSEN is not<br>used, this PSD301 input signal is tied<br>HIGH.                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|--------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | The PSD301 must be programmed using<br>WSI's MAPLE software package in the<br>following modes to achieve this<br>configuration:<br>8-bit data bus<br>Multiplexed address/data<br>R/W and E mode set<br>Active HIGH AS (ALE)<br>Active LOW RESET<br>Combined memory mode<br>Again, other parameters on the PSD301<br>can be set to fit additional design<br>requirements. These include the security<br>bit, the port I/Os, and the PAD inputs and<br>outputs.                                                                                                                                              |  |
| The "Smart"<br>Transmitter<br>Design.            | The microcomputer-based smart<br>transmitter design, by Bailey Controls,<br>requires program store 256K bits EPROM<br>for storing algorithms and data store 16K<br>bits SRAM for storing A/D, commu-<br>nication and LCD routines. It also<br>requires two octal latches, a PLD, and a<br>variety of glue logic to interface to its<br>68HC11 microcontroller, UART, and LCD<br>display. This is illustrated in Figure 7. Of<br>course, with board space on the digital<br>board being limited, another board would<br>have been needed to accommodate<br>these components, unless they in some<br>way could be integrated.                                                                                                                                                                                                                                                                                                                                                                                        | on one chip. It interfaces to the 68HC11<br>directly and actually integrates 8 chips<br>from the alternative design into one,<br>eliminating the need to add another board<br>The resultant architecture is illustrated in<br>Figure 8.<br>Note that in the alternative design shown<br>in Figure 7, ports typically lost when<br>connecting the microcontroller to external<br>memory had to be recreated externally with<br>latches and buffers when memory was<br>connected to the microcontroller. With the<br>PSD301, these ports are recreated inter-<br>nally, eliminating the latches and buffers. |  |
|                                                  | This is where the PSD301 provides<br>exceptional value. As discussed, the<br>PSD301 already integrates EPROM, <sup>1</sup><br>SRAM, <sup>2</sup> a PLD, and other glue logic all                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | For example, to interface the PSD301 to the 24-character LCD display, each pin of                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |

**PSD301** 

## The PSD301 streamlines a microcontroller-based smart transmitter design By Seyamak Keyghobad – Bailey Controls, and Karen Spesard – WSI

*The "Smart" Transmitter Design (Cont.)*  port A is configured as an I/O and mapped to the byte-wide LCD data inputs. Then to write to or read from the LCD display, port A is accessed like a memory-mapped peripheral via an address offset from the base CSIOPORT defined in the PAD. Since port A is qualified by and handled through the PAD, there is no need for an external octal latch. Other TTL logic is not required to interface to the 68HC11's control signals, memory, or peripherals either. It is all integrated in the PSD301. Thus, a smaller PLD than originally thought required in the design was used — a 16V8 instead of a 22V10 — because the PAD was able to reduce the amount of logic by creating chip selects for the UART and other logic functions.



# The PSD301 streamlines a microcontroller-based smart transmitter design By Seyamak Keyghobad – Bailey Controls, and Karen Spesard – WSI

**PSD301** 





## The PSD301 streamlines a microcontroller-based smart transmitter design By Seyamak Keyghobad – Bailey Controls, and Karen Spesard – WSI





GND

GND

## The PSD301 streamlines a microcontroller-based smart transmitter design By Seyamak Keyghobad - Bailey Controls, and Karen Spesard - WSI





**PSD301** 

# The PSD301 streamlines a microcontroller-based smart transmitter design By Seyamak Keyghobad – Bailey Controls, and Karen Spesard – WSI



# The PSD301 streamlines a microcontroller-based smart transmitter design By Seyamak Keyghobad – Bailey Controls, and Karen Spesard – WSI

**PSD301** 

PSD301 Bonuses Besides considerably reducing board space in this smart transmitter design by reducing parts count, several other benefits of the PSD301 were also seen. These include reliability improvement, power consumption savings, inventory savings, faster time-to-market, and cost savings.

Reliability was improved because there are seven less chips required for implementation that could fail in the design. Also, by reducing chip count, 112 pins and about 100 traces were eliminated and the number of layers on the board were reduced from 8 to 4, making failures due to open or shorted pins and traces less likely to occur.

Power consumption was reduced because much faster discrete EPROM and SRAM devices with access times of ~75 ns would have been required in conjunction with glue logic for selecting different devices instead of using the PSD301, saving at least 20 mA Icc. (The access time for the PSD301 memories include decoding and input address latch delays). If the power-down feature on the PSD301 were also used, power savings could be increased further. For example, in a system which is accessing the PSD301 only a quarter of the time, the power consumption could be reduced by 75% to 8 mA typical.

As an added benefit, the PSD301 helped reduce inventory significantly by obsoleting multiple chips. And, if last minute changes in the design were required, the PSD301 would be able to accomodate them without additional hardware modifications. So, purchasing line item management is made simpler and easier.

With the reprogrammable PSD301, development time was kept to a minimum by easily accommodating design iterations in both hardware and software. Changes in I/O, address mapping, bus interface, and code were simple to make. Also, debugging was made easier with the PSD301's on-chip SRAM for downloading test programs. This all helped to shorten the design development cycle, reduce development costs, and speed up market introduction of the smart transmitter.

By using the PSD301, cost savings were realized by reducing system cost with fewer boards (or reduced board space), improving reliability, and reducing inventory levels. Savings were also attributable to lower manufacturing costs because there were fewer parts to program and place. And by getting to market faster, profits were improved significantly.

| Summary | The PSD301 peripheral solved a funda-<br>mental problem often seen in that instead<br>of getting "locked into" an inflexible<br>multiple chip memory sub-system<br>solution, the PSD301 was able to provide | much higher integration and flexibility all<br>at the same time. Clearly, using the<br>PSD301 was the better choice for the<br>smart transmitter design.                                    |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Notes   | (please call your local WSI sales repre                                                                                                                                                                     | 302/312 w/512K bits EPROM and the<br>e available in the same pinout and packages<br>esentative for availability). Or, multiple PSD301s<br>ded benefit of increased functionality and I/O's. |
|         | glue logic. See Application Note 011. N                                                                                                                                                                     | led externally without requiring any additional<br>lote that many engineers have 8K x 8<br>cause they need it, but because 2K x 8 SRAMs                                                     |

PSD301

The PSD301 streamlines a microcontroller-based smart transmitter design By Seyamak Keyghobad – Bailey Controls, and Karen Spesard – WSI

#### Appendix 1. PSD301 Configuration

```
WSi PSD301 Configuration Save File for Smart Transmitter Design
                    ALIASES
CSO = ASICCS
GLOBAL CONFIGURATION
Address/Data Mode:
                                        MX
                                        8
Data Bus Size:
CSI/A19:
                                        CSI
Reset Polarity:
                                        LO
ALE Polarity:
                                        HI
WRD/RWE:
                                        RWE
A16-A19 Transparent or Latched by ALE:
                                        т
Using different READ strobes for SRAM and EPROM: N
PORT A CONFIGURATION (Address/IO)
Bit No.
          Ai/IO.
                    CMOS/OD.
   0
                    CMOS
           IO
   1
           IO
                    CMOS
   2
           IO
                    CMOS
   3
                    CMOS
           10
   4
           IO
                    CMOS
   5
           10
                    CMOS
                    CMOS
   6
           10
   7
                    CMOS
           10
PORT B CONFIGURATION
Bit No.
          CS/IO.
                    CMOS/OD.
   0
                     CMOS
           CS0
   1
           CS1
                     CMOS
   2
                     CMOS
           CS2
   3
           CS3
                     CMOS
   4
           CS4
                     CMOS
   5
           CS5
                     CMOS
   6
           CS6
                     CMOS
   7
           CS7
                     CMOS
       CHIP SELECT EQUATIONS
/ASICCS = /A15 * A14 * /A13 * /A12 * E
/CS1 = /A15 * A14 * /A13 * A12 * E
/CS2 = /A15 * A14 * A13 * /A12 * E
/CS3 = /A15 * A14 * A13 * A12 * E
/CS4 = /A15 * /A14 * /A13 * /A12 * /A11 * E
  + /A15 * /A14 * /A13 * /A12 * /A11 * / R/W
/CS5 = /A15 * /A14 * /A13 * /A12 * A11 * E
  + /A15 * /A14 * /A13 * /A12 * A11 * / R/W
/CS6 = /A15 * /A14 * /A13 * A12 * /A11 * E
  + /A15 * /A14 * /A13 * A12 * /A11 * / R/W
/CS7 = /A15 * /A14 * /A13 * A12 * A11 * E
  + /A15 * /A14 * /A13 * A12 * A11 * / R/W
```

**PSD301** 

The PSD301 streamlines a microcontroller-based smart transmitter design By Seyamak Keyghobad – Bailey Controls, and Karen Spesard – WSI

## Appendix 1. PSD301 Configuration (Cont.)

| pendix 1. PSD3                                                                                                                                                                                                       | 801 Configuration (Cont.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| *******                                                                                                                                                                                                              | PORT C CONFIGURATION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | *****                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | * |
| Bit No.<br>O<br>1<br>2                                                                                                                                                                                               | CS/Ai.<br>CS8<br>CS9<br>CS10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |
| CHI                                                                                                                                                                                                                  | P SELECT EQUATIONS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |
| /CS8 = /A15                                                                                                                                                                                                          | * /A14 * A13 * /A12 * /A11 *                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
| /CS9 = /A15                                                                                                                                                                                                          | * /A14 * A13 * /A12 * A11 * :                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
| /CS10 = /A15                                                                                                                                                                                                         | * /A14 * A13 * A12 * /A11 *                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
| ******                                                                                                                                                                                                               | **************************************                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | *****                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | * |
| 19 18 1<br>ESO N N<br>ES1 N N<br>ES2 N N<br>ES3 N N<br>ES4 N N<br>ES5 N N<br>ES6 N N<br>ES7 N N<br>RS0 N N N<br>CSP N N N<br>CSP N N N<br>CSP N N N<br>CADDRDAT<br>CRWR<br>CA19/(/CSI)<br>CALE<br>CRESET<br>COMB/SEP | A       A       A       A       A       A       SEGMT       SE         7       16       15       14       13       12       11       STRT       ST         N       N       1       0       0       N       8000       N       ST         N       N       1       0       0       N       8000       N       N       N       9000       N         N       N       1       0       1       N       9000       N       N       N       000       N         N       N       1       0       1       N       8000       N       N       N       000       N       N       N       0000       N       N       N       N       N       0000       N       N       N       N       N       N       N       N       N       N       N       N       N       N       N       N       N       N       N       N       N       N       N       < | EGMT         EPROM         EPROM         File Name           FOP         START         STOP           8FFF         8000         8fff         BCN2.0           9FFF         9000         9fff         BCN2.0           BFFF         b000         bfff         BCN2.0           BFFF         b000         bfff         BCN2.0           CFFF         c000         cfff         BCN2.0           DFFF         d000         dfff         BCN2.0           FFFF         6000         efff         BCN2.0           FFFF         6000         efff         BCN2.0           67FF         37FF         5000         ffff         BCN2.0           67FF         37FF         500         ffff         BCN2.0           CPAF1         [0] = 0         0         CPAF1         [1] = 0           CPAF1         [1] = 0         0         CPAF1         [2] = 0           CPAF1         [3] = 0         0         CPAF1         [5] = 0           CPAF1         [5] = 0         0         CPAF1         [6] = 0           CPAF1         [7] = 0         0         0         0 | * |
| CPAF2                                                                                                                                                                                                                | = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |
| CPACOD [0] =<br>CPACOD [1] =<br>CPACOD [2] =<br>CPACOD [3] =<br>CPACOD [4] =<br>CPACOD [5] =<br>CPACOD [6] =<br>CPACOD [7] =                                                                                         | 0<br>0<br>0<br>0<br>0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | CPBCOD [0] = 0<br>CPBCOD [1] = 0<br>CPBCOD [2] = 0<br>CPBCOD [3] = 0<br>CPBCOD [4] = 0<br>CPBCOD [5] = 0<br>CPBCOD [6] = 0<br>CPBCOD [7] = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |
| $\begin{array}{llllllllllllllllllllllllllllllllllll$                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | CPCF [0] = 1<br>CPCF [1] = 1<br>CPCF [2] = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |

#### Using the PSD3XX PAD for system logic By Jeff Miller – WSI

### PSD3XX

In 1990, WSI introduced the Programmable System Device (PSD): the first device in the world integrating UVEPROM, SRAM and programmable logic on a single chip of silicon. The highly-successful PSD301 was the first device in the PSD family and is currently used in applications ranging from fluid analyzers to high performance computers. The PSD device, by combining most of the peripheral functionality required by a typical microcontroller unit into one package, has enabled designers to greatly reduce part count, power and board space which has translated into significant cost savings.

Even if the PSD3XX family were simply a collection of EPROM and SRAM with an

on-chip decoder, it would be capable of adding significant value to the system into which it were designed. However, the PSD3XX family is much more than just a combination of memory devices. The onchip PLD may be used for many useful purposes in addition to providing the address decode capability. The purpose of this note is to demonstrate, in detail, the full capability of the PAD section of the PSD3XX family. A basic, though not extensive, knowledge of the PSD 3XX family and the Maple programming software is assumed by this note. Please consult Application Note 011 and/or the appropriate PSD3XX family data sheet for this general knowledge.

# PAD Architectue

The Programmable Array Decoder (PAD) contained in the PSD3XX family is a standard PLD array designed to provide all of the internal memory and I/O device chip selects as well as an external logic replacement capability. It has 14 inputs, 24 outputs and 40 product terms with which to perform these functions. See Figure 1 for an illustration of the PAD.

The PAD's 14 inputs are as follows:

- 🖵 A11 A19
- ALE or AS
- D RD or E
- □ WR or R/W

The A11 – A19 pins are labeled as address inputs, however, they do not have to be. A11 - A15 are generally sourced by the microcontroller or microprocessor that is connected to the PSD device. If the controller generates more than 16 bits of address, the A16 – A19 inputs may be used to connect the high order address bits for a full 1 MByte of address space. If the controller does not require this much address space, A16 – A19 may be used for other purposes, like general I/O or logic inputs.

A19 is multiplexed with the CSI signal, which is used to place the PSD device in a

low power mode when the system requires it. When configured as CSI, the A19 pin may not be used for any other purpose except the power down mode. In this mode, the  $\overline{CSI}$  signal is used by the PAD only to disable it, causing it to expend less power. When configured as A19, this signal may be used as a general purpose input to the PAD from the external system. This capability will be described in more detail later in this note. A16 - A18, when not necessary for address expansion, may also be used as general purpose inputs to the PAD. Thus, a total of four of the 14 PAD inputs may be general purpose, allowing the replacement of external logic by the PSD device. These inputs may be combined with the other PAD inputs to form complex equations involving addresses, strobes and external signals.

When attempting to visualize the full capability of the PAD outputs, it is most clear when it is broken into two sections, labeled in Figure 1 as PAD A and PAD B. PAD A is responsible for providing all of the internal chip selects for the EPROM, SRAM and I/O ports and the track mode control signals, and PAD B is responsible for the external logic replacement function.



#### PAD A

Thirteen of the 24 PAD outputs and thirteen of the 40 product terms are dedicated to PAD A. PAD A should be considered the internal address decoder, used to select the various on-chip memories and I/O devices according to the memory map programmed by the user. Each output has a single product term, allowing a particular

resource to be allocated a single contiguous range of addresses which will be used to access it. All of the PAD inputs are available for generation of the PAD A outputs, allowing the designer to select internal resources using any combination of address, strobe and external signals.

CSADOUT2

| PAD A<br>(Cont.) | The PAD A outputs are as follows: | CSADIN, CSADOUT1 and CSADOUT2 are<br>used to control the Track Mode operation. |
|------------------|-----------------------------------|--------------------------------------------------------------------------------|
| {00111.)         | ES0 – ES7                         | The Track Mode is an available option for                                      |
|                  |                                   | The track wode is an available option for                                      |
|                  | RS0                               | Port A to allow it to "track" the                                              |
|                  |                                   | Address/Data bus inputs to the PSD device                                      |
|                  | CSADIN                            | from the microcontroller. This provides the                                    |
|                  | CSADOUT1                          | capability to connect the PSD device, and                                      |

ES0 - ES7 are used to select the internal EPROM resources. Using the PSD301 as an example, there are eight select lines with which to access 32 KBytes of EPROM. Thus, each select line can enable a block of 4 KBytes of EPROM configured as 4K x 8 or 2K x 16. Each block must be contiguous, but the blocks may be placed anywhere within the address space of the microcontroller.

RS0 is used to select the SRAM resource. This single signal accesses a single 2 KByte block of SRAM which may be configured as 2K x 8 or 1K x 16. Again, this block must be contiguous but may be placed anywhere in the address map.

CSIOPORT is the signal which defines the base address of the on-chip I/O ports and control registers. The I/O ports and control registers occupy a 2K block of addresses which, like the memories, must be contiguous but may be located anywhere in the address space of the microcontroller. Once configured in the address map, CSIOPORT defines the base address of these ports and registers. An offset is added to the base address to individually access the registers. Table 1 below lists the offset values for these registers.

ation. n for device s the capability to connect the PSD device, and therefore the microcontroller, to one or more shared resources. These resources may be memory or other devices which must be accessed by more than one microprocessor or microcontroller.

CSADIN is generated when the microcontroller is attempting to read data from Port A in the track mode. It is generated from one product term involving the address inputs and the RD strobe (Intel mode) or R/W and E (Motorola mode). This allows the user to configure the address range in which the data is to be read from Port A. CSADOUT1 is generated when the microprocessor is accessing a "tracked" address. It is generated from a single product term involving the address inputs and ALE. When the address generated by the microcontroller is within the block specified by the user for track mode, and the ALE is active, CSADOUT1 becomes active, transferring the address and outputting it from Port A. CSADOUT2 is generated when the microcontroller is performing a write operation to a tracked address. It also has one product term involving the address inputs and WR (Intel mode) or R/W and E (Motorola mode). When the microcontroller performs a write to the appropriate address, CSADOUT2 is generated, transferring the data and outputting it from Port A. For further details on the operation of the Track Mode, please consult Application Note 017.

| Table 1.<br>I/O Port<br>Offset | Register Name                | Byte Size Access of the I/O Port Registers<br>Offset from the CSIOPORT |
|--------------------------------|------------------------------|------------------------------------------------------------------------|
| Addresses                      | Pin Register of Port A       | + 2 (accessible during read operation only)                            |
| Auto 05505                     | Direction Register of Port A | + 4                                                                    |
|                                | Data Register of Port A      | + 6                                                                    |
|                                | Pin Register of Port B       | + 3 (accessible during read operation only)                            |
|                                | Direction Register of Port B | + 5                                                                    |
|                                | Data Register of Port B      | +7                                                                     |

**PSD3XX** 

# Using the PSD3XX PAD for system logic

| Example:<br>Address<br>Mapping<br>With PAD A | In this example, we will choose a sample<br>address map which is similar to those used<br>in typical microcontroller applications. This<br>example assumes the use of a PSD301<br>device with 256 Kbits of EPROM and 16<br>Kbits of SRAM. Figure 2 below illustrates<br>our sample address map.                                                                                                                   | Configuring this memory map would<br>normally require designing a decoder to<br>generate the appropriate chip selects for<br>each given address range. For example,<br>assuming that a microcontroller with a 16-bit<br>address bus is used, the chip select for<br>EPROM bank 0 (ES0) would be generated<br>with the following equation:          |
|----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                              | In this example, we have located the boot<br>code and interrupt service routines begin-<br>ning at address 0000 in EPROM block 0.                                                                                                                                                                                                                                                                                 | ES0 = /A12 • /A13 • /A14 • /A15                                                                                                                                                                                                                                                                                                                    |
|                                              | The SRAM is located in the 2K block begin-<br>ning at address 0x1000 and can be used<br>for the stack and/or other scratchpad data.<br>The I/O ports occupy the 2K block begin-<br>ning at address 0x1800. Addresses in this<br>range will access ports A and B and their<br>control registers. The area from 0x2000 to<br>0x8FFF is unused in this example, though<br>it could be used for external resources as | Equations like this one would be formulated<br>for each of the chip selects, and the entire<br>function would probably be placed in some<br>kind of programmable device. When the<br>PSD device is used, PAD A replaces this<br>programmable device. Programming PAD A<br>to perform this function is a simple task<br>using WSI's Maple software. |
|                                              | will be shown later. Finally, the main<br>program resides in the 28K block of<br>EPROM located from address 0x9000 to<br>0xFFFF and is selected by ES1 – ES7.                                                                                                                                                                                                                                                     | Entering the ADDRESS MAP menu in the<br>Maple software running on a PC compatible<br>computer, the user will see a screen similar<br>to the one shown in Figure 3.                                                                                                                                                                                 |



**PSD3XX** 

# Using the PSD3XX PAD for system logic

| Example:<br>Address<br>Mapping With<br>Pad A (Cont.) | Upon displaying this screen, the Maple<br>software is ready for the user to enter the<br>memory map data. This is performed quite<br>simply by moving the cursor to the appro-<br>priate point with the arrow keys, and then<br>entering the appropriate data. The address<br>mapping may be entered in either of two<br>ways. First, the user may select each<br>address bit individually for each chip select<br>and enter a 0 or 1 as appropriate for the<br>equation desired. In our example, for ES0<br>we would enter a 0 in the columns for A12,<br>A13, A14 and A15. The other bits are don't<br>cares. In the other method of programming<br>the pad, the user simply moves the cursor<br>to the SEGMT START column and enters<br>the desired starting address for the block.<br>Again, using our sample memory map, the<br>user would move to the SEGMT START<br>column for ES0 and enter 0000. Maple | then automatically programs the 0's and 1's<br>into the address bits correctly to program a<br>4K block of EPROM beginning at address<br>0x0000. Note that all EPROM blocks must<br>begin on 4K boundaries. Figure 3 shows<br>the resulting address map table for our<br>example.<br>The address inputs which were unused in<br>this example (A16, A17, A18 and A19)<br>could have been used as general purpose<br>inputs to the PAD for specialized control of<br>the on-chip memory and I/O resources.<br>When this is done, the designer has<br>complete flexibility as to the configuration<br>of the PSD device resources and may<br>easily absorb many system functions into<br>the PSD device. More detail about the use<br>of A16 – A19 will be provided later in<br>this note. |
|------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PAD B                                                | Eleven of the PAD outputs and 27 of the<br>product terms are dedicated to PAD B.<br>Where PAD A was used to control the on-<br>chip PSD device resources, PAD B controls<br>any off-chip resources required by the<br>system. As with PAD A, all inputs to the<br>PAD are available to PAD B, allowing the<br>system designer to formulate outputs<br>involving any combination of address,<br>strobes and external signals. Unlike PAD A,<br>several of the outputs of PAD B have up to<br>four product terms each.                                                                                                                                                                                                                                                                                                                                                                                            | The outputs of PAD B are as follows:<br>CS0 – 7 (Port B)<br>CS8 – 10 (Port C)<br>The outputs from PAD B are brought to the<br>outside world through Port B and Port C.<br>These outputs are called chip selects,<br>though they may be used for any function<br>whatsoever. The port pins are configured<br>as selected by the user when the device is<br>programmed with the Maple output file.<br>There are many configuration options for<br>each port pin.                                                                                                                                                                                                                                                                                                                          |

# Figure 3. Mapie Address Map Entry

| X | X<br>X          | X<br>X                                 | 0                                                                             | 0                                                    | 0                                                    |                                                      |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | STOP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | START                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | STOP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | FILE NAME                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---|-----------------|----------------------------------------|-------------------------------------------------------------------------------|------------------------------------------------------|------------------------------------------------------|------------------------------------------------------|------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| X | Х               | ×                                      |                                                                               |                                                      | •                                                    | 0                                                    | Ν                                                    | 0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | OFFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|   |                 | ∧                                      | 0                                                                             | 0                                                    | 0                                                    | 1                                                    | N.                                                   | 9000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 9FFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| X | Х               | х                                      | 1                                                                             | 0                                                    | 1                                                    | 0                                                    | Ν                                                    | A000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | AFFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| x | Х               | х                                      | 1                                                                             | 0                                                    | 1                                                    | 1                                                    | N                                                    | B000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | BFFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| X | Х               | х                                      | 1                                                                             | 1                                                    | 0                                                    | 0                                                    | Ν                                                    | C000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | CFFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| X | Х               | х                                      | 1                                                                             | 1                                                    | 0                                                    | 1                                                    | Ν                                                    | D000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | DFFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| x | Х               | х                                      | 1                                                                             | 1                                                    | 1                                                    | 0                                                    | Ν                                                    | E000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | EFFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| X | х               | х                                      | 1                                                                             | 1                                                    | 1                                                    | 1                                                    | Ν                                                    | F000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | FFFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| x | Х               | х                                      | 0                                                                             | 0                                                    | 0                                                    | 1                                                    | 0                                                    | 1000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 17FF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| x | Х               | х                                      | 0                                                                             | 0                                                    | 0                                                    | 1                                                    | 1                                                    | 1800                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1FFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|   | × × × × × × × × | × ×<br>× ×<br>× ×<br>× ×<br>× ×<br>× × | x x x<br>x x x | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | X       X       X       1       0       1       1         X       X       X       1       1       0       N         X       X       1       1       0       1       N         X       X       1       1       0       1       N         X       X       1       1       0       1       N         X       X       1       1       1       0       N         X       X       1       1       1       N         X       X       X       1       1       1       N         X       X       X       0       0       1       0 | X       X       1       0       1       1       N       B000         X       X       1       1       0       1       1       N       B000         X       X       1       1       0       0       N       C000         X       X       1       1       0       1       N       D000         X       X       1       1       0       1       N       E000         X       X       1       1       1       1       N       F000         X       X       1       1       1       1       N       F000         X       X       0       0       0       1       0       1000         X       X       0       0       0       1       1       1800 | X       X       X       1       0       1       1       N       B000       BFFF         X       X       X       1       1       0       0       N       C000       CFFF         X       X       X       1       1       0       1       N       D000       DFFF         X       X       X       1       1       0       1       N       D000       DFFF         X       X       X       1       1       1       N       E000       EFFF         X       X       X       1       1       1       N       F000       FFFF         X       X       0       0       0       1       0       1000       17FF         X       X       0       0       0       1       1       1800       1FFF | X       X       X       1       0       1       1       N       B000       BFFF         X       X       1       1       0       0       N       C000       CFFF         X       X       1       1       0       1       N       D000       DFFF         X       X       1       1       0       1       N       D000       DFFF         X       X       1       1       1       0       N       E000       EFFF         X       X       1       1       1       N       F000       FFFF         X       X       0       0       1       0       1000       17FF         X       X       0       0       1       1       1800       1FFF | X       X       X       1       0       1       N       B000       BFFF         X       X       1       1       0       0       N       C000       CFFF         X       X       1       1       0       1       N       D000       DFFF         X       X       1       1       0       1       N       D000       DFFF         X       X       1       1       1       N       E000       EFFF         X       X       1       1       1       N       F000       FFFF         X       X       1       1       1       N       F000       FFFF         X       X       0       0       1       0       1000       17FF         X       X       0       0       1       1       1800       1FFF |

ADDRESS MAP

**PSD3XX** 

| PAD B   | If you require more information about port      |
|---------|-------------------------------------------------|
| (Cont.) | configuration, please consult application       |
|         | note 011. If the port outputs are               |
|         | configured as chip selects (outputs from        |
|         | the PAD), they may not be used for any          |
|         | other purpose. For example, the three Port      |
|         | C signals may be configured as chip             |
|         | selects (outputs) or addresses (inputs) but     |
|         | cannot be both. Fortunately, the flexibility of |
|         | the PSD device and the Maple software           |
|         | allows the designer to configure each Port      |
|         | B and C pin individually, so that the number    |
|         | of outputs and inputs may be optimized for      |
|         | a particular design requirement. See Table      |
|         | 2 below for an example of this flexibility.     |

This sample port configuration demonstrates all of the possible uses of a particular port pin. Though only Ports B and C may be inputs or outputs to/from the PAD, Port A is included in the table for completeness. In this example, five of the port pins are configured as PAD outputs (CS) and two are configured as PAD inputs (A). The remaining port pins in this example are configured as either I/O or address outputs. Several of the CS outputs have been configured as open drain. This allows them to be connected together in a wired OR configuration to increase the number of product terms even further if desired.

| Table 2.      | Pin | Configuration            | CMOS/OD |
|---------------|-----|--------------------------|---------|
| Sample Port   | PA0 | Address Out              | CMOS    |
| Configuration | PA1 | Address Out              | CMOS    |
|               | PA2 | Address Out              | CMOS    |
|               | PA3 | Address Out              | CMOS    |
|               | PA4 | I/O                      | CMOS    |
|               | PA5 | I/O                      | OD      |
|               | PA6 | I/O                      | OD      |
|               | PA7 | I/O                      | CMOS    |
|               | PB0 | CS0<br>CS1<br>CS2<br>CS3 | CMOS    |
|               | PB1 | CS1                      | CMOS    |
|               | PB2 | CS2                      | OD      |
|               | PB3 | CS3                      | OD      |
|               | PB4 | I/O                      | CMOS    |
|               | PB5 | I/O                      | CMOS    |
|               | PB6 | I/O                      | CMOS    |
|               | PB7 | I/O                      | CMOS    |
|               | PC0 | A16                      |         |
|               | PC1 | A17                      | —       |
|               | PC2 | CS10                     | OD      |

#### Example: Generating a Logic Equation With PAD B

Assume that it is necessary to generate the following equation given the port configuration in Table 2 above. This equation is a simple OR of three product terms.

CS0 = A15 • A14 • /A13 • /A17 • RD + /A15 • A14 • A12 • WR + A16

Figure 4 illustrates the Maple programming sequence to generate this equation.

To program this equation, the PORT B menu is entered from the Maple software. CS0 is selected by moving the cursor to it using the arrow keys. With CS0 selected, the user then presses the F3 key to bring up the CHIP SELECT DEFINITION table for CS0. The table contains four rows for data entry, each one corresponding to one of the available product terms for CS0. Implementing this equation required using three of the four available product terms. The fourth is left blank and will not be used to generate the output.

To enter the equation into the table, simply move the cursor around into the appropriate position and enter a 1 if the corresponding signal should be high for the equation to be true, 0 if it should be low, and X or SPACE if the signal is a don't care. The first term of the equation requires a low on A17, a high on A15, a high on A14, a low on A13 and a high on RD for the term to become active. Thus, 1's are placed in the A15, A14 and RD positions,

#### Example: Generating a Logic Equation With PAD B (Cont.)

and 0's are placed in the A17 and A13 positions. The remaining terms in the equation are entered in the same way. Note that A17 and A16 in this example need not be address bits, but may instead be used to bring external signals into the PAD. Four product terms are available on each of the CS0 – CS3 outputs, two terms are available on the CS4 – CS7 outputs and one term is available on CS8 – CS10. When planning the use of the PAD outputs, it is important to consider this so that the most efficient use of the product terms can be achieved.

| Figure 4.<br>Programming<br>PAD Outputs | PIN<br>PB0                                    | CS/I/O<br>CS0                                      | CMOS/OD<br>CMOS           |                           |                           |                           | rt B<br>XHIP              | SELE                      | ECT [                     | DEFI               | NITIO              | N CS               | 50                |                   |     |
|-----------------------------------------|-----------------------------------------------|----------------------------------------------------|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|--------------------|--------------------|--------------------|-------------------|-------------------|-----|
|                                         | PB1<br>PB2<br>PB3<br>PB4<br>PB5<br>PB6<br>PB7 | PB2CS2CMOSPB3CS3CMOSPB4CS4CMOSPB5CS5CMOSPB6CS6CMOS | <b>A19</b><br>X<br>X<br>X | <b>A18</b><br>X<br>X<br>X | <b>A17</b><br>0<br>X<br>X | <b>A16</b><br>X<br>X<br>1 | <b>A15</b><br>1<br>0<br>X | <b>A14</b><br>1<br>1<br>X | <b>A13</b><br>0<br>X<br>X | A12<br>X<br>1<br>X | A11<br>X<br>X<br>X | ALE<br>X<br>X<br>X | RD<br>1<br>X<br>X | WR<br>X<br>1<br>X |     |
|                                         | CS de<br>0 to s<br>in col<br>"don't           | elect Act                                          |                           | al, X to                  | meai                      | n "doi<br>othei           | n't ca                    | re", S<br>k col           | PACI                      | EBAF               | R to e<br>be tre   | rase.              | Enter<br>as       |                   | les |

#### Application Examples

The following section will illustrate the use of the PAD for system logic replacement in some common microcontroller applications.

#### **Basic Chip Select Generation**

One of the simplest uses of PAD B is the generation of chip selects for off-chip resources such as I/O devices or memories. Figure 5 below depicts the connection between a 68HC11 microcontroller, the PSD301 and two common peripheral devices: the 8250 UART and the 8254 counter/timer.

The 68HC11 is an 8-bit microcontroller with a 16-bit address bus. The lower 8 bits of address are multiplexed with the data bus while the upper 8 bits are transmitted on their own bus. An address strobe (AS) is provided to latch the address off of the multiplexed bus. A R/W signal indicates whether the current bus transaction is a read or a write (R/W = 1 = read, R/W = 0 =

write). The E signal is the clock used to strobe the data in or out of the microcontroller. The PSD301 can be configured to exactly match this signal definition and then connected as shown in the diagram. Not all of the 68HC11 or PSD301 signals are shown, only those relevant to this example of PAD capability.

The 8250 is a UART device commonly used in microcontroller systems to provide a serial data communication port. It has a simple bus interface, yet does not directly connect with the 68HC11 bus architecture. It requires an 8-bit bus to transfer data to and from the microcontroller and a separate 3-bit address bus used to access its internal registers. It also requires a chip select and separate read and write strobes (RD and WR). The chip select is generated by decoding the address from the microcontroller. The RD and WR signals may be generated from the R/W and E signals

# PSD3XX



Application Examples (Cont.) according to the following equations:

 $/RD = /(R/\overline{W} \cdot E)$ 

 $/\mathsf{WR}=/(/\mathsf{R}/\overline{\mathsf{W}}\boldsymbol{\cdot}\mathsf{E})$ 

These equations may be easily generated using PAD B and sent out through two of the chip select outputs. We have chosen CS5 and CS6, which come out on PB5 and PB6, for this example.

In order to provide the address lines to the 8250, we have configured Port A to output the latched address. This eliminates the need for any external latches to demultiplex the address/data bus from the microcontroller. Though all eight of the Port A pins have been configured as address outputs in this example, it is possible to configure only those address bits required for the application, A0 - A2 in this example, and configure the remaining Port A pins as general I/O.

The 8254 is a programmable interval timer which, like the 8250, is a peripheral used in

many microcontroller applications. Its bus connection is very similar to the 8250, allowing it to use the same read and write strobes (RD and WR) and address lines. It also requires a chip select which is decoded from the microcontroller address.

The chip selects for both of the peripheral devices may be easily decoded from the address inputs to PAD B. Normally, the addresses which are inputs to the PAD (A11 – A19) would give decoding resolution down to 2K. This means that each of the two peripheral devices that require chip selects would be allocated an address range of at least 2K. Since these devices do not require this much space and the 68HC11 has only a 16-bit address bus, it is possible to use the high order address inputs of the PSD device to improve the decoding resolution. To achieve this goal, we have configured Port C as address inputs A16 - A18, but have connected them to A8 - A10 from the microcontroller. This means that the PAD will now have

Application

Examples

(Cont.)

# Using the PSD3XX PAD for system logic

access to A8 – A15 for decoding, thus providing a resolution of 256 instead of 2K. This could actually be further reduced to a resolution of 128 if we were to configure the A19/CSI input to be A19, and then connect it to A7 from the microcontroller. In this example, we have not done this so that CSI is still available to place the PSD301 into low power mode if required.

We now have to define the addresses of each of the peripherals so that the chip select equations may be defined. We will start from the memory map provided earlier in Figure 2. This map allocated all of the internal resources of the PSD device. The external peripherals may be easily added to the unused area between addresses 0x2000 and 0x8FFF. Figure 6 depicts the new map with the external devices added. Notice that the internal resources can keep their original address mapping even though the additional address inputs (A8 - A10)have been added. This is because these inputs may be don't cares in the decoding for the internal resources even when they are being used for the external resources.

Now, to wrap up this simple design, we must enter the configuration and mapping information into Maple. The configuration of the PSD device must be consistent with the operation of the 68HC11 microcontroller. The address/data mode must be multiplexed, the data bus must be 8 bits wide, CSI/A19 may be configured either way, the reset polarity should be active low, the ALE polarity is active high, the read and write lines must be R/W and E, A19 – A16 should be latched so that these bits become available just like the rest of the address bus, and the read strobes for the



## Using the PSD3XX PAD for system logic

| Application<br>Examples<br>(Cont.) | <ul> <li>SRAM and EPROM will be the same. This configuration should be entered from the configuration menu of the Maple software.</li> <li>The address map programming for this example will remain the same as the one used earlier in Figure 3. The only items remaining are the programming of the ports and the generation of the equations for the chip selects and read/write strobes. First we must configure Port A to provide the latched address to the peripherals. This is accomplished by entering the PORT A menu in the Maple software. Maple will then ask you if you would like Port A configured for address I/IO or the Track Mode. For this example, we will use the address/I/O configuration. Next, Port A must be configured pin for pin as an address output. This is easily performed by using the cursor keys to select the appropriate pin and pressing the SPACE BAR to change the configuration. It is also possible to configure each pin as an open drain or CMOS output, but for address outputs, it is better to make them CMOS.</li> <li>Now, PORT C must be configured to provide the three additional address inputs. This is performed by entering the PORT C menu in Maple and selecting the appropriate pin with the cursor. Each pin should be configured as an address bit (Ai). Maple will call the pins A16 – A18 even though we will be using them as A8 – A10.</li> </ul> | Lastly, we must configure the Port B<br>outputs to become the chip selects and<br>read/write strobes. First, the PORT B menu<br>must be entered. Now, we must configure<br>each pin as an I/O or CS output.<br>PB0 – PB3 may be configured as general<br>purpose I/O pins. PB4 – PB7 must be<br>configured as chip selects. Once config-<br>ured as chip selects, the equations for each<br>output may be entered by following the<br>Maple instructions. The procedure is the<br>same as the one used in the earlier chip<br>select example. Our equations, including<br>the ones developed earlier for the read and<br>write strobes, are defined for each output<br>as follows:<br>PB5 = /CS5 = /RD = /(R/W • E)<br>PB6 = /CS6 = /WR = /(/R/W • E)<br>PB4 = /CS4 = /8250CS = /(A15 • /A14 •<br>A13 • /A12 • /A11 • /A18 • /A17 • /A16)<br>PB7 = /CS7 = /8254CS = /(A15 • /A14 •<br>A13 • /A12 • /A11 • /A18 • /A17 • A16)<br>This completes the design integrating these<br>four components with no additional logic<br>whatsoever. There is also additional space<br>in the PAD for more functions if necessary,<br>so we have not yet reached the limit of the<br>integration possibilities with the PSD301. |
|------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait State<br>Generation           | Often, when using some of the newer high-<br>performance microcontrollers with slower<br>external peripherals, it is not possible to<br>complete a read or write cycle to the<br>peripheral in the time allowed by the micro-<br>controller's minimum bus cycle. In this<br>case, one or more wait states must be<br>added to slow the controller down to the<br>speed of the peripheral. One way of doing<br>this is to fix a number of wait states for all<br>bus cycles to allow the slowest device<br>enough time for its access. Some<br>controllers even provide the capability to do<br>this internally through the programming of a<br>register. This works, of course, but can<br>severely impact the performance of the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | because one or more of the external<br>devices requires some number of wait<br>states. It is possible, with minimal logic, to<br>create a completely programmable auto-<br>matic wait state generator using the<br>PSD301 which will allow the fast resources<br>to operate at zero wait states and still<br>provide from one to eight wait states for the<br>slower resources.<br>For this example, we will use an Intel<br>80C196KB microcontroller running at 12<br>MHz. This controller has the capability to<br>operate in a 16-bit data mode, providing<br>the opportunity to further increase perfor-<br>mance if the system can also operate in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

system. There is no need to penalize the

ill use an Intel ller running at 12 s the capability to mode, providing er increase performance if the system can also operate in this mode. The PSD301 does have the capability of operating in the 16-bit mode, making it a good match for the 80C196. We will assume that the 80C196 must be

performance of the entire system, which

can include zero wait state memory

devices and other peripherals, simply

Wait State

Generation

(Cont.)

Figure 7. Memory Map

### Using the PSD3XX PAD for system logic

interfaced to several slow 8-bit peripherals requiring from one to eight wait states. With the PSD301, we can provide the correct number of wait states for each peripheral with the added capability of dynamically sizing the bus to the appropriate width for the current access.

The memory map we will use for this design is depicted in Figure 7. The internal resources of some 80C196 derivatives occupy most of the address space from 0x0000 to 0x3FFF, though some have less resources. Therefore, we have constructed the memory map to place the PSD device resources above address 0x4000. The PSD301 SRAM and I/O devices occupy from address 0x4000 to 0x4FFF. This leaves the area from 0x5000 to 0x7FFF for external peripherals while leaving 0x8000 to 0xFFFF for the EPROM banks. We assume that we must connect three external peripherals to the PSD device using this address space, one requiring one wait state, one requiring three and one requiring six. This memory map is entered into the part similarly to the previous examples.

To achieve the variable number of wait states, the ideal solution is to decode the address to determine the number of wait states required for a particular address range, and then to use a counter to count the appropriate number. By using the PAD to initialize an external counter, a variable wait state counter can be created in this manner. This wait state generator requires only one external device, a 74FCT191 counter. The circuit used to implement this function is illustrated in Figure 8. The 80C196KB is directly connected to the PSD device which in turn provides the three chip select signals for the external peripherals (PER1CS, PER2CS and PER3CS) as well as the wait state generator function and the dynamic bus sizing. Ports B and C are fully utilized to provide the logic inputs and outputs required to implement these functions, while Port A is still available for general I/O or address use.

This circuit uses PAD B to decode the addresses driven by the microcontroller and provide four outputs, based on these

| FFFF         |                        | וך       | ES7    |   | 60 - 64K |
|--------------|------------------------|----------|--------|---|----------|
| - 1          |                        |          | ES6    | _ | 56 - 60K |
|              |                        |          | ES5    |   | 52 - 56K |
|              | MAIN                   |          | ES4    |   | 48 - 52K |
|              | PROGRAM                |          | ES3    | - | 44 - 48K |
| 1            |                        |          | ES2    | — | 40 - 44K |
|              |                        |          | ES1    |   | 36 - 40K |
| 8000<br>7FFF |                        | 44       | ES0    | _ | 32 - 36K |
| 7000         | PERIPHERAL # 3<br>1 WS |          | 7      | _ | 28 - 32K |
| 6FFF         |                        |          |        |   |          |
|              | PERIPHERAL # 2<br>6 WS |          | 5      | - | 24 - 28K |
| 6000<br>5FFF |                        | 11       |        |   |          |
|              | PERIPHERAL # 1<br>3 WS |          | 5      | - | 20 - 24K |
| 5000<br>4FFF |                        | -1.1     |        |   |          |
|              | I/O PORTS              | USING CS | IOPORT |   | 18 - 20K |
| 4800         |                        |          |        |   |          |
| 47FF         |                        | 11       |        |   |          |
|              | SRAM                   | USING RS | 0      | — | 16 - 18K |
| 4000         |                        | 1)       |        |   |          |
| 3FFF         | 80C196KB               |          |        |   |          |
| 0000         | INTERNAL RESOURCE      |          |        |   |          |

Wait State

Generation

(Cont.)

# Using the PSD3XX PAD for system logic

# PSD3XX

addresses, which are used to initialize the 74FCT191 counter with its initial value. The counter is initialized using ALE to latch these four PAD outputs. The load signal for the counter is active low, however, while ALE is active high, so ALE is inverted using PAD B and sent out through Port C. Though the 80C196KB can be configured to provide an active-low address strobe, ADV, the timing of the signal is inappropriate for use as the LOAD input to the counter. Once the counter is initialized, it counts up from the initial value until the most significant bit increments from 0 to 1. The output of the most significant counter bit is routed to the READY input of the microcontroller. Thus, the controller will be held in wait states until the most significant counter bit is incremented. This output is also routed to the CTEN signal of the counter so that counting will cease once the READY signal has been issued to the controller. The clock for the counter is an inverted version of the CLKOUT signal from the controller. This clock must be inverted since the 80C196KB uses the falling edge of the clock to sample the READY input. PAD B again provides the

inversion function by routing CLKOUT into one of the Port C pins, inverting it and routing it back out through another Port C pin.

The counter provides from zero to eight wait states depending on the initialized value. For zero wait states, the most significant counter bit is initialized to a "1", which provides the READY signal to the controller immediately and disables the counter from incrementing. If one wait state is desired, the counter is loaded with the value 7 (0111 binary) so that after it increments once, the most significant bit switches to a "1" and provides the READY to the controller. When two wait states are required, a 6 (0110 binary) is loaded into the counter, and so on for the rest of the wait state values.

To properly size the bus to the appropriate width, PAD B is again used to decode the addresses of the 8-bit devices. When the address of an 8-bit device is encountered, the BUSWIDTH signal is driven to configure the 80C196KB address to eight bits. For all other addresses, the width is



PBO--PB3

1010

0100 1110

PSD3XX

# Using the PSD3XX PAD for system logic

| Generation<br>(Cont.)output from one of the Port B pins.PC0 = /LOAD = /ALE<br>PC1 = /CLKOUT = /A18The PSD device must now be configuration of the<br>provide the functions required by the<br>example circuit. The configuration of the<br>PSD must first be programmed to function<br>with the 80C196KB. This is easily<br>performed by the Maple software as in the<br>previous example. The address/data mode<br>should be 16 bits, CSI/A19 may be<br>configured as required for the application,<br>the reset polarity should be active high, sepa-<br>rate RD and WR strobes should be used<br>and A19 – A16 should be transparent, not<br>latched, since they are used as logic inputs<br>to the PAD.PC0 = /LOAD = /ALE<br>PC1 = /CLKOUT = /A18Next, we must program the functionality of<br>Port C. For this example, PC0 and PC1 are<br>used as outputs from the PAD to provide<br>the LOAD and CLK signals for the '191<br>counter. This is performed by entering the<br>PORT C menu in Maple and configuring<br>PC0 and PC1 as CS8 and CS9, respec-<br>tively. PC2 is used to input the CLKOUTPort A is usually configured next, and in<br>this example it is free to be configured on<br>any mode necessary for the application. I<br>may become either I/O or address outputs<br>for the PAD inputs are don't<br>cares.Next, we must program the functionality of<br>PORT C menu in Maple and configuring<br>PC0 and PC1 as CS8 and CS9, respec-<br>tively. PC2 is used to input the CLKOUT<br>signal from the microcontroller to the PAD<br>so that it may be inverted. Therefore, it<br>must be configured as address input A18.We are now ready to configure Port B. The<br>example requires that all of the Port B pir<br>be used as chip selects (logic outputs) for<br>PAD B. PB0 – PB3 are used to initialize to<br>counter with the correct number of wait<br>states for each device. These outputs are<br>deined according to the address rang | Table 3.                            | Perinheral No Address Banne                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | No Wait States PRO-PR3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Generation<br>(Cont.)output from one of the Port B pins.PC0 = /LOAD = /ALEThe PSD device must now be configured to<br>provide the functions required by the<br>example circuit. The configuration of the<br>PSD must first be programmed to function<br>with the 80C196KB. This is easily<br>performed by the Maple software as in the<br>previous example. The address/data mode<br>should be multiplexed, the data bus width<br>should be 16 bits, CSI/A19 may be<br>configured as required for the application,<br>the reset polarity should be active low, the<br>ALE polarity should be active low, the<br>ALE polarity should be active low, the<br>RED and WR strobes should be usedPC0 = /LOAD = /ALE<br>PC1 = /CLKOUT = /A18The equations are programmed by enteri<br>the CHIP SELECT DEFINITION menu for<br>each of the two chip selects, as in the<br>previous example. And entering the appro-<br>priate 1's, 0's and DON'T CARES. In the<br>case of PC0, there are don't cares in all of<br>the PAD inputs except ALE, where there is<br>a 0. Similarly, for PC1, the A18 input is a<br>while the rest of the PAD inputs are don't<br>cares.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                     | latched, since they are used as logic inputs<br>to the PAD.<br>Next, we must program the functionality of<br>Port C. For this example, PC0 and PC1 are<br>use <u>d as o</u> utputs from the PAD to provide<br>the LOAD and CLK signals for the '191<br>counter. This is performed by entering the<br>PORT C menu in Maple and configuring<br>PC0 and PC1 as CS8 and CS9, respec-<br>tively. PC2 is used to input the CLKOUT<br>signal from the microcontroller to the PAD<br>so that it may be inverted. Therefore, it<br>must be configured as address input A18.<br>Now, the equations used to generate the<br>PC0 and PC1 outputs must be entered into<br>the PAD. PC0 is the LOAD signal which is<br>just the ALE input inverted. PC1 is an<br>inverted version of A18, which contains the | <ul> <li>this example it is free to be configured in any mode necessary for the application. It may become either I/O or address outputs, or may be set in the Track Mode as described earlier.</li> <li>We are now ready to configure Port B. This example requires that all of the Port B pins be used as chip selects (logic outputs) from PAD B. PB0 – PB3 are used to initialize the counter with the correct number of wait states for each device. These outputs are defined according to the address ranges for each of the peripherals and the number of wait states required for each. Table 3 summarizes the outputs required for each peripheral so that we may define the</li> </ul> |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Wait State<br>Generation<br>(Cont.) | output from one of the Port B pins.<br>The PSD device must now be configured to<br>provide the functions required by the<br>example circuit. The configuration of the<br>PSD must first be programmed to function<br>with the 80C196KB. This is easily<br>performed by the Maple software as in the<br>previous example. The address/data mode<br>should be multiplexed, the data bus width<br>should be 16 bits, CSI/A19 may be<br>configured as required for the application,<br>the reset polarity should be active low, the<br>ALE <u>po</u> larity <u>sho</u> uld be active high, sepa-                                                                                                                                                                                                   | PC0 = /LOAD = /ALE<br>PC1 = /CLKOUT = /A18<br>The equations are programmed by entering<br>the CHIP SELECT DEFINITION menu for<br>each of the two chip selects, as in the<br>previous example, and entering the appro-<br>priate 1's, 0's and DON'T CARES. In the<br>case of PC0, there are don't cares in all of<br>the PAD inputs except ALE, where there is<br>a 0. Similarly, for PC1, the A18 input is a 0<br>while the rest of the PAD inputs are don't                                                                                                                                                                                                                                      |

| Table 3.              | Peripheral No. | Address Range | No. Wait States |
|-----------------------|----------------|---------------|-----------------|
| Wait State<br>Summary | 1              | 0x5000-5FFF   | 3               |
| Summary               | 2              | 0x6000-6FFF   | 6               |
|                       | 3              | 0x7000-7FFF   | 1               |

PSD3XX

# Using the PSD3XX PAD for system logic

| Wait State<br>Generation<br>(Cont.) | This table can be easily used to form the<br>necessary equations for PB0 – PB3. PB3<br>can be considered the enable for the wait<br>state generator which is active low only in<br>the address ranges of the three peripher-<br>als. It must remain high for all other<br>address ranges. The other three outputs<br>simply encode the proper number of wait<br>states. The resulting equations are listed<br>below: | Finally, PB7 is used to perform the bus<br>sizing function. It should be sized to eight<br>bits whenever any of the external peripher-<br>als is accessed. It should be sized to 16<br>bits for all other accesses. The 80C196KB<br>requires a high on the BUSWIDTH input for<br>16-bit operation and a low for 8-bit opera-<br>tion. This is accomplished by the equation<br>below: |
|-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                     | PB0 = /QA = /(A15 • A14 • A13 • /A12)                                                                                                                                                                                                                                                                                                                                                                                | PB7 = BUSWIDTH = /(A15 • A14 • A13 +<br>/A15 • A14 • /A13 • A12)                                                                                                                                                                                                                                                                                                                     |
|                                     | PB1 = /QB = /(A15 • A14 • /A13 • A12)                                                                                                                                                                                                                                                                                                                                                                                | This completes the equations for Port B.<br>These equations are entered in the Maple                                                                                                                                                                                                                                                                                                 |
|                                     | PB2 = /QC = /(A15 • A14 • A13 • /A12)                                                                                                                                                                                                                                                                                                                                                                                | software by selecting the Port B chip select<br>definition screens as described in the previ-                                                                                                                                                                                                                                                                                        |
|                                     | PB3 = /QD = /(A15 • A14 • /A13 • A12 +<br>/A15 • A14 • A13 • /A12 + /A15 • A14 •<br>A13 • A12)                                                                                                                                                                                                                                                                                                                       | ous example and entering 1's and 0's in the<br>appropriate locations. Remember that don't<br>cares (X's or blanks) must be entered in all<br>inputs which are not used by a particular                                                                                                                                                                                               |
|                                     | PB4 – PB6 are used as chip selects for<br>each of the three peripherals and are                                                                                                                                                                                                                                                                                                                                      | equation.                                                                                                                                                                                                                                                                                                                                                                            |
|                                     | simply decoded from the address inputs by<br>PAD B corresponding to the address<br>ranges listed in Table 2. These equations<br>are listed below:                                                                                                                                                                                                                                                                    | Finally, we must enter the memory map<br>into Maple Address Map screen. This is<br>performed as in the previous example by<br>entering 1's, 0's or don't cares in the appro-<br>priate places.                                                                                                                                                                                       |
|                                     | PB4 = /PER1CS = /(A15 • A14 •<br>/A13 • A12)                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                      |
|                                     | PB5 = /PER2CS = /(A15 • A14 •<br>A13 • /A12)                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                      |
|                                     | PB6 = /PER3CS = /(A15 • A14 •<br>A13 • A12)                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                      |

#### Conclusion

The PSD device may be used in a variety of applications requiring the simplicity, space savings and performance possible by the integration of memory and programmable elements. But a significant portion of the value of the PSD device, is its ability to absorb much of the logic functionality which normally surrounds a microcontroller application. The programmability of the device allows the designer to make changes to both the software and the design itself as required. This is not possible with masked ROM or ASIC-based designs. The PSD device can truly turn a microcontroller into a complete two-chip solution.

PSD3XX

#### Using memory paging with the PSD3XX By Jeff Miller – WSI

#### .

Introduction

The PSD3XX is a compact, high performance microcontroller peripheral used to extend the capabilities of a microcontroller in a space-limited embedded control system. It provides the programmable logic, memory and I/O requirements needed by most microcontroller designs in a single small package.

The PSD301, introduced in November 1990, was the first of a six-member family of devices providing varying amounts of on-chip resources. The PSD301 contains 32K Bytes of EPROM for program storage and 2K Bytes of SRAM scratchpad memory. As the family expanded, the EPROM memory size grew to 128K Bytes in some versions. This large memory may be needed in many applications requiring large feature sets. In many cases the microcontroller is capable of addressing only 64K Bytes of memory with its limited 16-bit address bus. In these applications, the designer is often faced with the difficult choice of eliminating features, using a more expensive microcontroller with a wider address bus, or adding external paging logic requiring several extra components.

With this in mind, designers at WSI have included a simple but very effective paging system in the PSD3XX models containing more than 32K Bytes of EPROM. This enables cost effective microcontrollers like the 80C31, 80196, Z80, 68HC11 and others to take full advantage of additional memory without any additional hardware or design effort.

#### What is Paging?

The primary purpose of a page register is to extend the width of the address bus by a number of bits to increase the size of the address space. These bits are added to the address bus as outputs of a register which is loaded from the data bus of the MCU. Each additional bit doubles the effective address space. Though the page register address bits increase address space, they are not the same as the true address bits which are generated by the microcontroller since they do not appear with the same timing or sequence of the address. They must be controlled carefully to avoid unexpected behavior. They can also be a problem for compiler-generated code since the compiler does not inherently know how to use a page register. Because of this, the designer must take care in designing software which uses the PSD3XX page register.

The purpose of this note is to explain the usage of the page register and some of the techniques which may be used when designing software which uses the page register. A typical page register design is shown in Figure 1. In the figure, a typical 8-bit microcontroller with a multiplexed address/data bus is shown connected with the logic required to implement a 4-bit page register. The least significant address bits are demultiplexed from the data bus by the '573 transparant latch, which is clocked by the ALE signal. The most significant 8-bits of address are driven directly by the microcontroller. When combined with the least significant address bits from the address latch, the address bus is 16-bits wide. This provides the capability to directly access 64K Bytes of address space, which may be any combination of program and data storage. To implement more address space, two '74 devices (a dual D-type flip flop) have been used to create a page register. The inputs of the '74 are four bits of the address/data bus. These bits are stored into the '74 when a write to a specific address, as decoded by the '138, is performed by the microcontroller. The outputs of the '74 form an additional 4 address bits, thus extending the address bus to 20-bits or 1 MByte of address space. The '74 page register can be considered to hold a page number. Each page number provides a complete duplication of the microcontroller's memory space. To get to another 64K Byte page of address space,

# Using memory paging with the PSD3XX

the controller simply has to change the page number by writing a different value to the page register.

The circuit below has one major complication. If the microcontroller is currently in a particular memory page, page X, and it changes the page number to Y using a store instruction which it fetched from page X, as soon as the store is complete the next instruction fetched will come from page Y. This means that page Y must pick up the programming sequence exactly as it was left off from page X. This is a complication that must be handled in software and can make programming very difficult. Additionally, interrupts can be a significant problem since they must force the program to an interrupt vector which may exist on a different page.



## The PSD3XX Implementation

What is

Paging

(Cont.)

Figure 2 illustrates the block diagram of the PSD3XX with the internal page register. It is similar to the discrete circuit above, but with some important differences. The page register provides 4-bits of additional addressing capability, but does not provide them directly to the memory devices themselves. Instead, the page register output bits are taken into the Programmable Array Decoder of the PSD3XX. This enables the user to program them as necessary for the system design.

The PAD provides a flexibility that most page register implementations are not capable of providing. If you are unfamiliar with the capabilities of the PSD3XX PAD, please consult Application Note 014, Using the PSD3XX PAD for System Logic Replacement . Figure 3 illustrates the PAD logic in a PSD3XX with a page register. The PAD generates the outputs which are used to select the PSD3XX's eight EPROM blocks, the SRAM block, the I/O ports, the shared resource interface, the page register itself and all external functions which use the chip selects provided by Port B and Port C of the PSD3XX. Thus, the page register bits may be combined with the address bits and control signals in any combination to generate the select signals for all of the above resources. In addition, any or all of the page register bits may be don't cares in any or all of the PAD chip select equations, enabling the user to select which resources may be selcted from which page, or to select some resources from any page. This extremely useful feature enables the programmer to avoid the problem of software continuity between pages described above by making at least one of the EPROM blocks appear in all pages and then using that block to contain code for interrupt servicing and page switching. This is performed simply by making the page register bits 'don't cares' in the chip select equation for that block. All of this is fully programmable with the PSD3XX, enabling the designer to choose the paging scheme that is best for the application.

## Application Note 015

# Using memory paging with the PSD3XX





#### The PSD3XX Implementation (Cont.)

The Microcontroller can write or read the page register to place a new page number in it or read the current page number. To perform this, the microcontroller must simply access the address programmed in the PAD for the page register. This address is based on the CSIOPORT select signal programming. If address 8000 hex is programmed for CSIOPORT, the corresponding page register address is 8018 hex and read and write data will be to and from the page register.



## PSD3XX

#### A Simple Paging Example

To illustrate the operation of the PSD3XX page register, assume that a designer requires a full 128K Bytes of program storage space, 32K Bytes of buffer SRAM and three peripheral devices which also must be memory mapped. We can also assume that the required program is easily broken into four modules which are somewhat independent, but do need the capability to call one another and must be able to pass global data among one another. Further, assume that the external peripheral devices may be selected from three of the four modules, but must not be accessed from the fourth for security reasons. Lastly, assume that the designer is constrained by cost and compatibility considerations to use an 8-bit microcontroller with a 16-bit address bus (in this example, an 8031).

These requirements may be easily implemented using the PSD313 device. The PSD313 is an 8-bit device with 128K Bytes of EPROM for program storage. It also contains the PAD and page register logic described above. The memory map required for this application is shown in Figure 4.

The memory map shown utilizes the page register to provide a unique address for all of the PSD313's 128K Bytes of EPROM in addition to the SRAM and peripherals. This memory map consists of four pages of 64K Bytes each. The map is further divided into program and data space by the PSEN and RD signals which are available in the 8031 microcontroller. This enables the PSD313 to overlap the addresses of the EPROM, I/O and SRAM. The pages are numbered 0 - 3, and are written into the page register is part of the I/O addressing and resides in the RD = 0 map.

The software must be broken into four segments, one residing in each page, in order to function efficiently with this memory scheme. The software which enables the machine to boot, service interrupts and switch memory pages is located in a block of EPROM which is mapped into all memory pages. This enables simple page switching and interrupt servicing regardless of the page that the microcontroller is currently operating in. Locating an EPROM block in multiple pages is very simple using the PAD 'don't care' feature. In this example, EPROM block 0 has been chosen to hold the page-independent software. The PAD output which controls block 0 is ES0. Therefore, in the definition of the ES0 signal, all four of the page register bits (P0 – P3) are programmed as 'don't cares'. ES0 is further defined to be from address 0000 to 3FFF. Thus, whenever the microcontroller places an address on the bus which is in this range with PSEN low, the data will be read from EPROM block 0, regardless of the contents of the page register.

The remaining EPROM blocks are evenly distributed into the four pages. This segmentation has been used in this example, but there is no requirement that the pages contain equal memory sizes. Each can have a different amount of resources contained within it. We have placed EPROM blocks 1 and 2 in page 0. This is done by requiring P0 – P3 to be 0's to generate the ES1 and ES2 selects. Similarly, ES3 and ES4 in page 1, ES5 and ES6 in page 2 and ES7 in page 3 require the P0 – P3 signals to be in the correct states to generate the ES signals.

The SRAM and I/O devices most likely must be accessible from all pages, like the page switching software and interrupt service routines. In this way, each of the program segments may store and load data from the SRAM which may be used to pass global parameters among the programs. All programs may also communicate with the external I/O devices. which is most likely required. It is very important that the internal PSD3XX I/O registers, which include the I/O port control and data registers as well as the page register itself, be mapped into all pages. Otherwise, after the page has been switched, there will be no way of switching back to the original page since the page register would not be accessible. To make the page register accessible from all pages, the designer must simply make the page register bits (P0 - P3) 'don't cares' in the equation for the CSIOPORT signal. This can also be done for any of the external chip select equations which are generated by the PAD and brought to the outside world through Port B or Port C.

#### PSD3XX

# PSD3XX

## Figure 4. Memory Map



## Using memory paging with the PSD3XX

A Simple Paging Example (Cont.) If it is desirable for some pages not to have access to some resources, this may be done also. The designer must simply use the page register bits in the equation which selects the resource which is to be protected. This can provide a program security or error handling feature while protecting certain I/O or memory devices from accidental corruption.

Figure 5 contains the output of WSi's Maple software for the above example. The part chosen to implement the sample design was the 8-bit only PSD313, chosen because it contains the required 128K Bytes of EPROM but is less expensive than the PSD303. The PSD303, which also contains 128K Bytes of EPROM, can be configured in a 16-bit data bus mode which would be suitable for use with 16-bit microcontrollers like the 80196.

The PSD313 was programmed and configured to implement the memory map shown in Figure 4. Not all of the capability of the PSD313 has been utilized in this example but is available to satisfy other system design requirements if necessary. The PSD313 has been configured to function with the 8031 microcontroller and its associated control signals. This can be seen in the Configuration portion of the output file in Figure 5. We have also configured Port B 0-3 to provide the required chip select functions for the external I/O and SRAM devices. These chip selects have been given the aliases ExtCS1, ExtCS2 and ExtCS3 for the I/O devices and SRAMCS for the SRAM. The equations entered for the chip selects correspond to the addresses for which they should be active. ExtCS1 will become active when address 8000 - 87FF hex is accessed. ExtCS2 and ExtCS3 will become active for addresses 8800 - 8FFF hex and 9000 - 97FF hex respectively. The SRAM chip select will become active for address 0 - 7FFF hex. All of these chip selects will function independently from the page register contents since the page register outputs (P0 - P3) do not appear in the equations. This means that all of these external devices will be selectable from any page.

The address map lists the start and stop addresses and the page numbers for each of the blocks of memory and I/O inside the PSD313. The first EPROM block is selected by ES0, which has been mapped from address 0000 to 3FFF hex. This block has been designated to contain the page switching software and the boot and interrupt service routines. Since all pages need the capability to switch from one to another, and since an interrupt may be received at any time while the software is executing in any page, EPROM block 0 has been made accessible from all pages by making the page register bits 'don't cares' (x's) in the address map for ES0.

ES1 and ES2 map EPROM blocks 1 and 2 into address 8000 – FFFF hex in page 0. Thus, whenever a program address within this range is accessed by the microcontroller while the page register contains a 0, ES1 or ES2 will activate EPROM block 1 or 2. While the microcontroller is executing code from one of these blocks in page 1, it may still access internal or external SRAM, or internal or external SRAM, or internal or external I/O without changing pages. ES3 – ES7 are mapped to pages 1 – 3 in a similar manner.

In addition to the external SRAM, the PSD313's internal SRAM has been mapped into all address pages where it may be used to supplement the microcontroller's register file and internal SRAM. This SRAM may be used for global variable storage, stack space or many other purposes. The PSD313's I/O ports have been mapped at address C800 - CFFF hex in this example. This places the page register address at C81A hex (see the PSD3XX data sheet for I/O addressing in the PSD3XX). As discussed earlier, the page register has been mapped into the same address from all memory pages, so that it may be accessed from all program subroutines in the system.

### Using memory paging with the PSD3XX

#### Figure 5. MAPLE Software Example

```
PSD PART USED: PSD313
Project Name : = Page Register App Note
Your Name : = Jeff Miller
Date : = 1/15/92
Host Processor: = 8031
*******
               *************************
/CS4
     = ExtCS1
     = ExtCS2
/CS5
     = ExtCS3
/CS6
/CS7
      = SRAMCS
*********************
              *************
Address/Data Mode: MX
Data Bus Size :
             8
Reset Polarity :
             HI
Security
             OFF
         :
ALE Polarity
         :
             ΗI
A15-A0 ALE dependent (Y) or Transparent (N):
                           N
Using Different READ strobes for Data and Program: Y
******
/RD and /WR
*****
ADDRESS/IO
PIN Ai/IO
         CMOS/OD
   A0
A1
PAO
           CMOS
          CMOS
PA1
   A2
PA2
          CMOS
   A3
PA3
           CMOS
PA4
    A4
           CMOS
    A5
PA5
           CMOS
    AG
PA6
           CMOS
PA7
    A7
           CMOS
*********************
Pin
   CS/IO
          CMOS/OD
PB0
    CS0
          CMOS
PB1
    CS1
          CMOS
PB2
    CS2
          CMOS
PB3
    CS3
          CMOS
PB4
    CS4
          CMOS
PB5
    CS5
          CMOS
PB6
    CS6
          CMOS
PB7
    CS7
          CMOS
```

Philips Semiconductors Microcontroller Peripherals

#### Application Note 015

**PSD3XX** 

Using memory paging with the PSD3XX

# Figure 5. MAPLE Software Example (Cont.)

| **************************************                                                                                                         |                                                      |                                                                                                   |                                                                               |                                                 |                                                           |                                                      |                                                                |                                                                                              |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                     |                                                                               |                                                                              |                                                                                                             |                                                                                  |                                                                                |  |  |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|---------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|-------------------------------------------------|-----------------------------------------------------------|------------------------------------------------------|----------------------------------------------------------------|----------------------------------------------------------------------------------------------|------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|-------------------------------------------------------------------------------|------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|--------------------------------------------------------------------------------|--|--|--|--|--|
| ExtCS                                                                                                                                          | 1                                                    | =                                                                                                 |                                                                               |                                                 |                                                           |                                                      |                                                                |                                                                                              |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | /A12 *<br>/A12 *                                                    |                                                                               |                                                                              |                                                                                                             |                                                                                  |                                                                                |  |  |  |  |  |
| ExtCS                                                                                                                                          | 2                                                    | =                                                                                                 |                                                                               |                                                 |                                                           |                                                      |                                                                |                                                                                              |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | /A12 *<br>/A12 *                                                    |                                                                               |                                                                              |                                                                                                             |                                                                                  |                                                                                |  |  |  |  |  |
| ExtCS                                                                                                                                          | 3                                                    | #                                                                                                 |                                                                               |                                                 |                                                           |                                                      |                                                                |                                                                                              |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | A12 *<br>A12 * ,                                                    |                                                                               |                                                                              |                                                                                                             |                                                                                  |                                                                                |  |  |  |  |  |
| SRAMC                                                                                                                                          | s                                                    | =                                                                                                 |                                                                               | 1                                               | (/]                                                       | <b>1</b> 5)                                          | )                                                              |                                                                                              |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                     |                                                                               |                                                                              |                                                                                                             |                                                                                  |                                                                                |  |  |  |  |  |
| ****                                                                                                                                           | ***1                                                 | ****                                                                                              | ***                                                                           | ***                                             | POI                                                       | RT C                                                 | c co                                                           | ONF:                                                                                         | IGUI                                                 | RATION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | *****                                                               | *****                                                                         | *****                                                                        |                                                                                                             |                                                                                  |                                                                                |  |  |  |  |  |
| Pin                                                                                                                                            |                                                      | cs/                                                                                               | 'Ai                                                                           |                                                 |                                                           | LO                                                   | SIC,                                                           | ADI/                                                                                         | DR                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                     |                                                                               |                                                                              |                                                                                                             |                                                                                  |                                                                                |  |  |  |  |  |
| PC0                                                                                                                                            |                                                      | AJ                                                                                                | 6                                                                             |                                                 |                                                           | LO                                                   | JIC                                                            |                                                                                              |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                     |                                                                               |                                                                              |                                                                                                             |                                                                                  |                                                                                |  |  |  |  |  |
| PC1                                                                                                                                            |                                                      | A                                                                                                 | .7                                                                            |                                                 |                                                           | LO                                                   | JIC                                                            |                                                                                              |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                     |                                                                               |                                                                              |                                                                                                             |                                                                                  |                                                                                |  |  |  |  |  |
| PC2                                                                                                                                            |                                                      | A                                                                                                 |                                                                               |                                                 |                                                           | LO                                                   | GIC                                                            |                                                                                              |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                     |                                                                               |                                                                              |                                                                                                             |                                                                                  |                                                                                |  |  |  |  |  |
| A19                                                                                                                                            |                                                      | CS                                                                                                | SI                                                                            |                                                 |                                                           |                                                      |                                                                |                                                                                              |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                     |                                                                               |                                                                              |                                                                                                             |                                                                                  |                                                                                |  |  |  |  |  |
| ****                                                                                                                                           | ***                                                  | ***1                                                                                              | ****                                                                          | ***                                             | ***                                                       | ***                                                  | ***                                                            | ***                                                                                          | ***                                                  | *****                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | *****                                                               | *****                                                                         | *****                                                                        |                                                                                                             |                                                                                  |                                                                                |  |  |  |  |  |
|                                                                                                                                                |                                                      |                                                                                                   |                                                                               |                                                 |                                                           |                                                      |                                                                |                                                                                              |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                     |                                                                               |                                                                              |                                                                                                             |                                                                                  |                                                                                |  |  |  |  |  |
| ****                                                                                                                                           | ****                                                 | ***1                                                                                              | ***                                                                           | ***]                                            | POR                                                       | r C                                                  | CH                                                             | IP (                                                                                         | SEL                                                  | ECT EQ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | UATION                                                              | 5****                                                                         | *****                                                                        |                                                                                                             |                                                                                  |                                                                                |  |  |  |  |  |
| ****                                                                                                                                           | ****                                                 | ***1                                                                                              | ***                                                                           | ***                                             | ***1                                                      | ***                                                  | ***                                                            | ***                                                                                          | *AD                                                  | DRESS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | MAP***                                                              | *****                                                                         | *****                                                                        | ******                                                                                                      | *******                                                                          | **************************************                                         |  |  |  |  |  |
|                                                                                                                                                |                                                      |                                                                                                   |                                                                               |                                                 |                                                           |                                                      |                                                                |                                                                                              |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                     |                                                                               |                                                                              |                                                                                                             |                                                                                  |                                                                                |  |  |  |  |  |
|                                                                                                                                                |                                                      |                                                                                                   |                                                                               |                                                 |                                                           |                                                      |                                                                |                                                                                              |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                     |                                                                               |                                                                              |                                                                                                             |                                                                                  |                                                                                |  |  |  |  |  |
|                                                                                                                                                | A                                                    | A                                                                                                 | A                                                                             | A                                               | A                                                         | А<br>14                                              |                                                                | A<br>12                                                                                      |                                                      | SEGMT<br>STRT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | SEGMT<br>STOP                                                       | FILE<br>STRT                                                                  | FILE<br>STOP                                                                 | File Name                                                                                                   |                                                                                  | Q.F<br>Ale                                                                     |  |  |  |  |  |
|                                                                                                                                                | A<br>19                                              | A                                                                                                 | A                                                                             | A                                               | A                                                         |                                                      | 13                                                             |                                                                                              | 11                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                     |                                                                               |                                                                              | File Name                                                                                                   | Page Reg                                                                         |                                                                                |  |  |  |  |  |
| ESO<br>ES1                                                                                                                                     | A                                                    | <b>A</b><br>18                                                                                    | а<br>17                                                                       | А<br>16                                         | <b>A</b><br>15                                            | 14                                                   |                                                                | 12                                                                                           |                                                      | STRT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | STOP                                                                | STRT                                                                          | STOP                                                                         |                                                                                                             | Page Reg<br>3210                                                                 | ĀLE                                                                            |  |  |  |  |  |
| ES0                                                                                                                                            | A<br>19<br>N                                         | <b>A</b><br>18<br>0                                                                               | а<br>17<br>0                                                                  | А<br>16<br>0                                    | <b>A</b><br>15<br>0                                       | 14<br>0                                              | 13<br>N                                                        | 12<br>N                                                                                      | 11<br>N                                              | STRT<br>0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | STOP<br>3fff                                                        | STRT<br>0                                                                     | STOP<br>3fff                                                                 | PROG0.HEX                                                                                                   | Page Reg<br>3210<br>XXXX                                                         | ĀLE<br>X                                                                       |  |  |  |  |  |
| ESO<br>ES1                                                                                                                                     | A<br>19<br>N<br>N                                    | <b>A</b><br>18<br>0<br>0                                                                          | <b>A</b><br>17<br>0<br>0                                                      | A<br>16<br>0<br>0<br>0                          | <b>A</b><br>15<br>0<br>1                                  | 14<br>0<br>0<br>1                                    | 13<br>N<br>N                                                   | 12<br>N<br>N                                                                                 | 11<br>N<br>N<br>N<br>N                               | STRT<br>0<br>8000<br>c000<br>8000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | STOP<br>3fff<br>bfff                                                | STRT<br>0<br>0                                                                | STOP<br>3fff<br>3fff<br>7fff<br>3fff                                         | PROG0.HEX<br>PROG1.HEX                                                                                      | Page Reg<br>3210<br>XXXX<br>0000                                                 | ALE<br>X<br>X<br>X<br>X<br>X                                                   |  |  |  |  |  |
| ESO<br>ES1<br>ES2<br>ES3<br>ES4                                                                                                                | A<br>19<br>N<br>N<br>N                               | A<br>18<br>0<br>0<br>0<br>0<br>0                                                                  | A<br>17<br>0<br>0<br>0<br>0<br>0                                              | A<br>16<br>0<br>0<br>0<br>0<br>0                | <b>A</b><br>15<br>0<br>1<br>1<br>1                        | 14<br>0<br>0<br>1<br>0<br>1                          | 13<br>N<br>N<br>N<br>N<br>N                                    | 12<br>N<br>N<br>N<br>N<br>N                                                                  | 11<br>N<br>N<br>N<br>N<br>N                          | STRT<br>0<br>8000<br>c000<br>8000<br>c000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | STOP<br>3fff<br>bfff<br>ffff<br>bfff<br>ffff                        | STRT<br>0<br>4000                                                             | STOP<br>3fff<br>3fff<br>7fff<br>3fff<br>7fff                                 | PROG0.HEX<br>PROG1.HEX<br>PROG1.HEX<br>PROG2.HEX<br>PROG2.HEX                                               | Page Reg<br>3210<br>XXXX<br>0000<br>0000<br>0001<br>0001                         | ALE<br>X<br>X<br>X<br>X<br>X<br>X<br>X                                         |  |  |  |  |  |
| ESO<br>ES1<br>ES3<br>ES4<br>ES5                                                                                                                | A<br>19<br>N<br>N<br>N<br>N<br>N                     | A<br>18<br>0<br>0<br>0<br>0<br>0<br>0<br>0                                                        | A<br>17<br>0<br>0<br>0<br>0<br>0<br>0                                         | A<br>16<br>0<br>0<br>0<br>0<br>0<br>0           | A<br>15<br>0<br>1<br>1<br>1<br>1                          | 14<br>0<br>0<br>1<br>0<br>1<br>0                     | 13<br>N<br>N<br>N<br>N<br>N<br>N                               | 12<br>N<br>N<br>N<br>N<br>N<br>N                                                             | 11<br>N<br>N<br>N<br>N<br>N<br>N                     | STRT<br>0<br>8000<br>c000<br>8000<br>c000<br>8000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | STOP<br>3fff<br>bfff<br>ffff<br>bfff<br>ffff<br>bfff                | STRT<br>0<br>4000<br>0<br>4000<br>0                                           | STOP<br>3fff<br>3fff<br>7fff<br>3fff<br>7fff<br>3fff                         | PROG0.HEX<br>PROG1.HEX<br>PROG1.HEX<br>PROG2.HEX<br>PROG2.HEX<br>PROG3.HEX                                  | Page Reg<br>3210<br>XXXX<br>0000<br>0000<br>0001<br>0001<br>0010                 | ALE<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X                               |  |  |  |  |  |
| ES0<br>ES1<br>ES3<br>ES4<br>ES5<br>ES6                                                                                                         | A<br>19<br>N<br>N<br>N<br>N<br>N<br>N<br>N           | A<br>18<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0                                                   | A<br>17<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0                               | A<br>16<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0 | A<br>15<br>0<br>1<br>1<br>1<br>1<br>1<br>1                | 14<br>0<br>0<br>1<br>0<br>1<br>0<br>1                | 13<br>N<br>N<br>N<br>N<br>N<br>N                               | 12<br>N<br>N<br>N<br>N<br>N<br>N<br>N                                                        | 11<br>N<br>N<br>N<br>N<br>N<br>N<br>N                | STRT<br>0<br>8000<br>8000<br>c000<br>8000<br>c000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | STOP<br>3fff<br>bfff<br>ffff<br>ffff<br>ffff<br>bfff<br>ffff        | STRT<br>0<br>4000<br>0<br>4000<br>0<br>4000                                   | STOP<br>3fff<br>3fff<br>3fff<br>3fff<br>7fff<br>3fff<br>3fff<br>7fff         | PROG0.HEX<br>PROG1.HEX<br>PROG2.HEX<br>PROG2.HEX<br>PROG3.HEX<br>PROG3.HEX                                  | Page Reg<br>3210<br>XXXX<br>0000<br>0000<br>0001<br>0001<br>0010<br>0010         | ALE<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X                          |  |  |  |  |  |
| ES0<br>ES1<br>ES2<br>ES4<br>ES5<br>ES5<br>ES7                                                                                                  | A<br>19<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N      | A<br>18<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0                                         | A<br>17<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0                          | A<br>16<br>00000000000000000000000000000000000  | A<br>15<br>0<br>1<br>1<br>1<br>1<br>1<br>1                | 14<br>0<br>0<br>1<br>0<br>1<br>0<br>1                | 13<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N                     | 12<br>N<br>N<br>N<br>N<br>N<br>N<br>N                                                        | 11<br>N<br>N<br>N<br>N<br>N<br>N<br>N                | STRT<br>0<br>8000<br>8000<br>c000<br>8000<br>c000<br>c000<br>c000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | STOP<br>3fff<br>bfff<br>ffff<br>bfff<br>ffff<br>bfff<br>ffff<br>fff | STRT<br>0<br>4000<br>4000<br>0<br>4000<br>0<br>4000<br>0                      | STOP<br>3fff<br>3fff<br>3fff<br>3fff<br>7fff<br>3fff<br>7fff<br>3fff<br>3fff | PROG0.HEX<br>PROG1.HEX<br>PROG1.HEX<br>PROG2.HEX<br>PROG2.HEX<br>PROG3.HEX<br>PROG3.HEX                     | Page Reg<br>3210<br>XXXX<br>0000<br>0000<br>0001<br>0001<br>0010<br>0010<br>0    | ALE<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X                |  |  |  |  |  |
| ES0<br>ES12<br>ES34<br>ES56<br>ES57<br>RS0                                                                                                     | A<br>19<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N | A<br>18<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                     | A<br>17<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0                | A<br>16<br>00000000000000000000000000000000000  | A<br>15<br>0<br>1<br>1<br>1<br>1<br>1<br>1<br>1           | 14<br>0<br>0<br>1<br>0<br>1<br>0<br>1<br>1<br>1      | 13<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N      | 12<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>O                                              | 11<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>O | STRT<br>0<br>8000<br>c000<br>8000<br>c000<br>c000<br>c000<br>c000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | STOP<br>3fff<br>bfff<br>ffff<br>bfff<br>ffff<br>bfff<br>ffff<br>fff | STRT<br>0<br>4000<br>0<br>4000<br>0<br>4000<br>0<br>0<br>N/A                  | STOP<br>3fff<br>3fff<br>7fff<br>3fff<br>7fff<br>3fff<br>3fff<br>N/A          | PROG0.HEX<br>PROG1.HEX<br>PROG1.HEX<br>PROG2.HEX<br>PROG2.HEX<br>PROG3.HEX<br>PROG3.HEX<br>PROG4.HEX<br>N/A | Page Reg<br>3210<br>XXXX<br>0000<br>0001<br>0001<br>0010<br>0010<br>0011<br>XXXX | ALE<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X      |  |  |  |  |  |
| ESS<br>ESS2<br>ESS3<br>ESS5<br>ESS6<br>ESS6<br>CSF                                                                                             | A<br>19<br>NNNN<br>NNN<br>NNN<br>NNN<br>NNN          | A<br>18<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 | A<br>17<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 | A<br>16<br>00000000000000000000000000000000000  | A<br>15<br>0<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1      | 14<br>0<br>0<br>1<br>0<br>1<br>0<br>1<br>1<br>1<br>1 | 13<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>O<br>O | 12<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>O<br>O                                    | 11<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>1      | STRT<br>0<br>8000<br>c000<br>8000<br>c000<br>c000<br>c000<br>c000<br>c                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | STOP<br>3fff<br>bfff<br>ffff<br>bfff<br>ffff<br>ffff<br>ffff<br>fff | STRT<br>0<br>4000<br>0<br>4000<br>0<br>4000<br>0<br>0<br>N/A<br>N/A           | STOP<br>3fff<br>3fff<br>7fff<br>3fff<br>7fff<br>3fff<br>3fff<br>3ff          | PROG0.HEX<br>PROG1.HEX<br>PROG1.HEX<br>PROG2.HEX<br>PROG2.HEX<br>PROG3.HEX<br>PROG3.HEX<br>PROG4.HEX<br>N/A | Page Reg<br>3210<br>XXXX<br>0000<br>0000<br>0001<br>0010<br>0010<br>0010<br>0    | ALE<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X |  |  |  |  |  |
| ES0<br>ES1<br>ES2<br>ES3<br>ES5<br>ES5<br>ES5<br>ES5<br>ES7<br>RS0<br>CSP<br>*****<br>Pin F<br>Direc<br>Data<br>Pin F<br>Direc<br>Data<br>Page | A 19<br>N N N N N N N N N N N N N N N N N N N        | A<br>18<br>00<br>00<br>00<br>00<br>00<br>00<br>00<br>* * * exit<br>strist<br>strist<br>strist     | A<br>17<br>00000000000000000000000000000000000                                | A6<br>000000000****<br>fsofso:                  | <b>A</b><br>15<br>01111111<br>11************************* | 14<br>0010101111<br>** AD<br>ft B<br>ft B<br>ft B    | 13<br>NNNNNNNN<br>** RE tt:<br>                                | 12<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>S<br>S<br>E<br>B | 11<br>NNNNNNN<br>** OCCCCCC                          | STRT<br>0<br>8000<br>c000<br>8000<br>c000<br>c000<br>c000<br>c800<br>c800<br>c800<br>c800<br>c800<br>c800<br>c800<br>c800<br>c800<br>c800<br>c800<br>c800<br>c800<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c900<br>c90 | STOP<br>3fff<br>bfff<br>ffff<br>bfff<br>ffff<br>ffff<br>ffff<br>fff | STRT<br>0<br>4000<br>4000<br>0<br>4000<br>0<br>N/A<br>N/A<br>******<br>****** | STOP<br>3fff<br>3fff<br>7fff<br>3fff<br>7fff<br>3fff<br>N/A<br>N/A<br>****** | PROG0.HEX<br>PROG1.HEX<br>PROG1.HEX<br>PROG2.HEX<br>PROG3.HEX<br>PROG3.HEX<br>PROG4.HEX<br>N/A<br>N/A       | Page Reg<br>3210<br>XXXX<br>0000<br>0000<br>0001<br>0010<br>0010<br>0010<br>0    | ALE<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X |  |  |  |  |  |

#### *Software Considerations*

The software example shown in Figure 5, has been divided into four sections to facilitate placing it into the four pages. These four program blocks have been called PROG1.HEX, PROG2.HEX, PROG3.HEX and PROG4.HEX. In order to create these files to be loaded into the PSD3XX, the software designer must plan for this event when the software is written. It is most easily accomplished by breaking the tasks into logical groups that do not need to access one another frequently. Most software can be split in this manner. Then, the designer can create the page switching algorithm which is used to jump between the tasks which are on different pages.

There are many ways to implement this capability, but we will provide as an example one method which can be used. This method of memory paging involves the use of a table of addresses and page numbers of all program tasks which may be called from page to page. This table can be made global when the code is compiled so that it may be used in all four of the programs used in this example. This table would reside in EPROM block 0 along with the interrupt service routines and page switching algorithms so that it may be accessed from all memory pages. Thus, when PROG1 is executing and must run a task or subroutine which is in PROG2, the software should jump to the page switching algorithm while passing the table lookup address of the task that it wishes to run. In this way, only the pointer into the table must be known by all programs instead of the address and page number of each routine. This simplifies the process of modifying the software by permitting the programmer to keep all of the pointers into the table constant, even if the actual subroutine addresses change. In this table, the page switching routine will find the page that it must switch to as well as the address to jump to after the page has been switched. The return address and page number may simply be pushed onto the stack, which is stored in the SRAM. Since the SRAM is also page independent, all programs may share the same stack.

To build the table, the labels of all subroutines which may be shared among pages must be accumulated from all of the programs. These labels must be placed in the table along with the corresponding page numbers. This table must then be placed in the global EPROM block. The labels must be made global so that each program may have access to them. Then pointers into the table must be assigned. one for each global subroutine. These must also be made global so that they may be used by each program. The pointers must remain constant, even when the software is modified. This way, software modifications may change the values of the labels, but not the pointers.

This provides a very clean paging solution which may be implemented using high level language compilers. The only penalty when using this method is the overhead experienced when switching from page to page. This overhead may be minimized by careful software design which minimizes the number of program calls and jumps between routines on different pages. Care must also be taken when nesting jumps from page to page if it is important to keep track of return addresses. Interrupts, since they are accessible from all pages, are very simple to handle. The page need not even be switched to service an interrupt unless the service routine needs to access a task which is not located in the global EPROM block. Even then, the only consideration is that before returning from the interrupt, the page number must be restored to its value prior to the interrupt. This paging scheme is illustrated in Figure 6.

# **PSD3XX**

#### Compiler Issues

The paging algorithm shown below is relatively easy to implement and somewhat automatic. However, it is not a totally transparent solution for the software programmer. There is such a solution available from at least one compiler manufacturer. Archimedes makes compilers for several microcontrollers including the 8031 family and 68HC11 family. These compilers are available with built in memory paging which use some of the microcontroller's port bits as additional address bits. These compilers generate bank switching code automatically which can be easily modified to utilize the page register inside the PSD3XX.

When this is done, the use of the page register becomes transparent to the user. The attached code excerpt shows the calling structure resulting from the use of the Archimedes compiler with the modifications to utilize the PSD3XX page register.



## **PSD3XX**

#### Archimedes Code

836 /\* Init DCC & SCR registers \*/ 837 838 init\_dsl\_hdsl\_dcc\_scr(); \ 0268 7400 MOV A,#\$BYTE3 init dsl hdsl dcc scr 026A 900000 MOV DPTR, #REFFN init\_dsl\_hdsl\_dcc\_scr ١ ١ 026D 120000 LCALL ?X\_CALL\_L18 839 840 /\* Init Master/Slave Polynomial \*/ 841 init\_ms\_poly(); 0270 7400 \ MOV A,#\$BYTE3 init ms poly 0272 900000 ١ MOV DPTR,#\$REFFN init ms poly 0275 120000 LCALL ?X\_CALL\_L18 ١ 842 843 844 845 } Notes: 1. \$Byte 3 is a directive that addresses the "page" of the specified function. 2. \$REFFN Addresses the 16-bit offset of the function. MODULE ?BANK\_SWITCHER\_L18 TITL '8051 - C - BANK-SWITCHER' RSEG RCODE ; ; - L18.S03 ï ; ; ; Function(s): Banked switched CALL and RET ; Must be tailored for actual bank-switching hardware. ï In the sample system the P1 port was used. ; ; ; ; Version: 4.00 [IANR] ; ; ; ; ; Call a non-local function ; ; ; ; --------; ; ; ; Inputs: ; ; Stack: 16-bit return address ; DPTR: 16-bit function-address ; ; A: 8-bit page address ; : ; ; 

The above Archimedes code is courtesy of Jeff Fayne, Tellabs, Inc.

.....

#### **Application Note 015**

;

;

;

;

;

;

**PSD3XX** 

## Using memory paging with the PSD3XX

### Archimedes Code (Cont.)

PUBLIC ?X\_CALL\_L18 ?X CALL L18 Save old bank PUSH P1 Bank-switch MOV Pl,A Go to function CLR A JMP @A+DPTR ; Leave current function ï ; ----; ï Input: ; Stack: 24-bit return address ; ; ; ;-----PUBLIC ?X\_RET\_L18 ?X RET L18: Bank-switch \_\_\_\_\_ POP P1 \*\*\*\*\* Return ------RET END

Conclusion

The PSD3XX page register system can greatly assist designers of systems requiring large memory spaces with 16-bit address buses. The PSD3XX offers capability not found in most discrete page register implementations. The capability to define global resources as well as page-specific resources enables the designer to implement the paging technique most suitable for the application. The page register is included in the PSD302, PSD312, PSD303 and PSD313 devices, all of which are pin compatible with one another. This provides the capability of expanding the memory size as required even after a system has been designed. The designer can simply drop the new, and larger, PSD3XX into the same footprint as the old, and update the software to add more memory pages. This capability can be important for product feature additions after a design is complete. Since the system is fully programmable, it may be updated and changed anytime.

# Power considerations in the PSD3XX

By Jeff Miller - WSI

| Introduction               | The PSD3XX is a configurable microcon-<br>troller peripheral integrating programmable<br>logic, EPROM and SRAM technologies into<br>a single piece of silicon. It has been used<br>extensively in microcontroller applications<br>around the world by virtue of its high level<br>of integration, configurability and ease of<br>use. This integration makes possible the<br>design of very compact microcontroller<br>systems, enabling the user to squeeze a<br>great deal of functionality into a very small<br>space. Thus, the PSD3XX has found its<br>way into many small hand-held and/or<br>battery operated applications such as<br>cellular phones, medical instrumentation<br>and laptop or notebook computers which<br>usually require, in addition to small space,<br>a very low power consumption.<br>The PSD3XX family is based on a patented<br>high-performance CMOS technology and,                                                                                                                                                               | like other CMOS devices, requires very<br>low power consumption even when no<br>particular effort is made to minimize the<br>PSD3XX power. But, when some special<br>care is taken during the programming<br>and configuration of the device, power can<br>be reduced even further, making the<br>PSD3XX even more valuable in these<br>power-sensitive applications. This<br>application note will describe the methods<br>which can be used to reduce the PSD3XX<br>power consumption in both active and<br>stand-by modes. It makes sense to use<br>some of these techniques even when low<br>power is not a primary design requirement<br>since they are easy to implement and<br>require no additional expense. We believe<br>that proper implementation of the material<br>in this note will make the PSD3XX an<br>invaluable member of any low-power<br>microcontroller system.                                                                                                                                                                                                     |
|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Power Use<br>In The PSD3XX | The PSD3XX contains several modules<br>internally, each of which can be considered<br>a power consumer when in operation.<br>These modules include the PAD,<br>(Programmable Address Decoder)EPROM<br>and SRAM blocks. The key to reducing the<br>power used by the PSD3XX is to reduce<br>the power used by each of these modules<br>individually.<br>Under normal operation, several of the<br>functional modules may be operating, while<br>others may be standing by. A module in<br>stand by uses much less power than one<br>that is active. For example, whenever the<br>SRAM is not being actively used, it is<br>disabled and therefore consumes less<br>power. This is also true of the PAD. A PAD<br>term which is inactive. This would also<br>be true of the EPROM. However, in some<br>PSD3XX models, the EPROM is always<br>active, in which case it will always draw<br>power. This is done in order to provide the<br>best access time possible for the EPROM.<br>The Low Power family of PSD3XXs does<br>not keep the EPROM enabled at all times, | and thus the designer can save power by<br>minimizing the time during which the<br>EPROM is accessed. Use of this feature<br>does impact the speed of the PSD3XX<br>EPROM, which results in the loss of the<br>120 ns speed grade. There are other<br>methods of reducing EPROM power even<br>when the EPROM is enabled. These will<br>be discussed in detail later in this note.<br>When the time that each PSD3XX function<br>is kept in standby mode is maximized, the<br>power expense is minimized.<br>There is a way to place the entire PSD3XX<br>into the standby mode at once, thereby<br>reducing power usage to the bare<br>minimum. This can be done through the<br>use of the CSI (Chip Select Input) pin.<br>When the PSD3XX is deselected by the<br>CSI pin, the entire part enters the standby<br>mode using only about 50 µA of current.<br>While in this mode, the PSD3XX is<br>incapable of performing any functions,<br>including PAD logic equations, but this is<br>an excellent method of reducing system<br>power in designs which have low active<br>duty cycles. |

#### CMOS Power Characteristics

As a CMOS part, the PSD3XX behaves in the same way as other CMOS devices in terms of power dissipation. The PSD3XX consumes the most power when the temperature is low, the voltage is high and the frequency is high. Low temperature in CMOS devices, unlike in bipolar devices, causes the transistors to speed up, thus consuming more power. Therefore, if the system will never operate in low temperature environments, power dissipation will be lower. Another result of this characteristic is that CMOS parts do not generally experience thermal runaway. As temperature increases, the power expended by the CMOS device decreases, thus the part tends to effectively cool itself off.

Another characteristic of CMOS devices is the effect of voltage variations. CMOS behaves similarly to TTL devices with respect to voltage. When input voltage rises, the current drawn by a CMOS device also rises. As input voltage falls, input current also falls. Thus, the CMOS device will draw the least current at its lowest allowable supply voltage. This voltage is 4.5V in the PSD3XX. Taking the voltage below this level will generally slow the device down to below its specified speed as well as jeopardize its data retention capability. Between 4.5 and 5.5V, the PSD3XX varies by about 0.85mA per 0.1V variation. Thus, the PSD3XX will draw approximately 0.85 mA less current at 4.9V than at 5.0V V<sub>CC</sub>.

Lastly, frequency of operation plays an important role in the power dissipation of a CMOS device. A CMOS gate expends the greatest power while it is switching between the logic 0 and logic 1 states, or vice versa. This can be easily understood when looking at the circuit diagram for a typical CMOS output shown in Figure 1.

#### Figure 1. Typical CMOS Output Circuit



The circuit above represents a typical CMOS inverter output. Normally, either the top transistor is off (output = logic 0) or the bottom transistor is off (output = logic 1). MOS transistors have very low leakage currents which means that under these normal conditions, very little current will be passing from V<sub>CC</sub> to ground. However, when the input to the inverter is switching. both transistors will not switch from their present conditions to their new conditions at precisely the same instant. Therefore, both transistors will be on for a very brief instant during the transition. During this time there is a low impedance path from V<sub>CC</sub> to ground and some current is drawn by the circuit. In addition, the output will have some load capacitance (C1) which must be charged during switching,

even if the load itself draws little or no static current. Thus, during the switching process the power expended by a CMOS device is at its highest.

The switching current drawn by the device is dependent on the number of times the outputs are forced to switch logic states in a unit of time. Therefore, the frequency of operation of the part directly influences its dynamic power consumption. The lower the operational frequency, the lower the dynamic power expended by the device. In the PSD3XX, frequency of operation is determined by the rate at which the addresses are changing, usually indicated by the frequency of the ALE or AS signal. Generally, the PSD3XX draws about 3 mA of additional current for each 1 MHz added to the frequency of operation.

# PSD3XX

#### Application Note 016

### PSD3XX

### Power considerations in the PSD3XX

*Power Management Techniques In The PSD3XX*  The above mentioned features and characteristics can be used to the designer's advantage when designing compact microcontroller systems which have a tight power budget. In the sections that follow, several methods for reducing the PSD3XX power will be presented.

#### **Power Down Mode**

Many system designs do not require the microcontroller, and therefore the PSD3XX, to operate continuously. Systems, like cellular telephones and notebook computers, spend a large amount of time inactive - waiting for something to happen like a press of a button or keyboard. During this time, many designers place the microcontroller into a low power idle or sleep mode. In the sleep mode, the controller expends significantly lower power. The microcontroller is usually awakened by some event - a key on a keypad being pressed, for instance, which may result in an interrupt. There is no need for the PSD3XX to be active during the time that the microcontroller is not active. Therefore,

the PSD3XX should be placed in the power down mode (CSI inactive) to reduce the PSD3XX current down to its standby value.

The PSD3XX must also be awakened when the microcontroller is awakened so that it may provide an instruction to the controller when it requires one. If the microcontroller itself has a chip select output, like the Motorola 683XX series controllers, it may be used to awaken the PSD3XX as necessary. However, if it does not, there will be a problem. If the microcontroller itself is used to power down the PSD3XX, through an I/O port pin for example, there will be no way to power up the PSD3XX again since the PSD3XX itself contains the instruction that the microcontroller must use to activate the CSI signal to awaken the PSD3XX. The way to correct this situation is to design a circuit which detects when the microcontroller is coming out of its power down mode before it must fetch the first instruction. Such a circuit is depicted in Figure 2



In this circuit diagram, a Motorola 68HC11 microcontroller is connected to a PSD3XX in a low power system. The circuit functions quite simply. The E signal from the HC11 is normally a free running clock at 1/4 the frequency of the input clock. When the HC11 is placed into the sleep mode by the software (by executing the STOP instruction), the E signal stops oscillating and remains low until an interrupt or internal timer event occurs. After the interrupt has been received by the controller, the E signal resumes toggling, but there will be a minimum of two E clock cycles prior to the first AS. This characteristic can be used to place the PSD3XX into its low power standby mode whenever the STOP has been executed in the HC11 and to awaken it before it must supply an instruction to the HC11.

Figure 2.

Simple Power Down Circuit

## Power considerations in the PSD3XX

#### *Power Management Techniques In The PSD3XX (Cont.)*

The ACT05 device shown in the diagram is simply an open collector inverter. When the E signal is oscillating, the output of the inverter will be toggling between ground and high impedance. When the output is at ground, the capacitor will rapidly discharge from its present state into the ACT05. When the output is high impedance, the capacitor will slowly charge up to V<sub>CC</sub> through the resistor. Thus, under normal operation the  $\overline{CSI}$  input of the PSD3XX will be at or near 0 V, provided the RC time constant is large enough to prevent the capacitor from charging up beyond a logic zero level of 0.6 V.

When the HC11 enters the sleep mode the E signal remains low. This enables the

capacitor to slowly charge up to a logic one level which then places the PSD3XX into the standby mode in which it will consume only about 50µA of current. After the controller exits the sleep mode, the E signal will resume oscillating which rapidly discharges the capacitor. This, in turn, activates the CSI input to the PSD3XX, bringing it out of the power down mode. Since the E signal will oscillate for at least two full cycles before the first AS strobe begins a new bus cycle, the PSD3XX will have ample time to recover from the power down mode before having to supply an instruction to the HC11 for processing. In operation, the circuit results in a timing diagram similar to the one in Figure 3.

## Figure 3. 68HC11 Stop Timing

May, 1993



A similar circuit can be used for Intel 8031 type controllers. Controllers conforming to the Intel 8031 family generally have two low power modes: IDLE and POWER DOWN. The IDLE mode causes the controller to cease instruction execution, but its internal clocks continue to run. This saves significant power while leaving the internal timers and other functions operational. When in the IDLE mode, both the ALE signal and the PSEN signal are held high. A circuit similar to the one illustrated for the 68HC11 may be used to detect the end of oscillation on the ALE signal. This circuit is shown in Figure 4.



## Power considerations in the PSD3XX

#### *Power Management Techniques In The PSD3XX (Cont.)*

The circuit operates on the same principle as the one used earlier for the Motorola processor. The ALE signal normally oscillates high for 2 clocks out of every 6 or 12 clocks, depending on whether instruction or data accesses are being performed. The software places the 8031 into the Idle mode by setting bit 0 in the PCON register. Once set, the ALE and PSEN signals remain high until an interrupt or hardware reset occur. During this time, the  $\overline{CSI}$  signal will float high with the RC circuit, as in the earlier example. The ACT09 is simply an AND gate with an open collector output. It performs the same function as the inverter in the previous example without inverting the signal. When an interrupt or reset is received, the ALE signal begins to toggle again, but at least two "dummy" unused ALE cycles will occur before the first meaningful instruction is fetched, giving the PSD3XX time to recover from the power down mode. The timing for the above circuit is shown in Figure 5.

#### Figure 5. 8031 Idie Timing



If the system requires truly the lowest power available, the 8031 POWER DOWN mode may be used. This disables all internal operations of the 8031 as well as the external ones. Thus, any on-chip peripherals like timers and serial communication links will be disabled. This places the controller into its lowest power mode possible. Software may place the 8031 into the POWER DOWN mode by setting bit 1 in the PCON register. When execution of the instruction is complete, the ALE signal will be driven low and will remain in this state until a hardware reset is received. Thus, a circuit similar to the one above may be used to detect the static condition of the ALE signal, but an inverting gate must be used instead of the ACT09 (such as the ACT05 used in the Motorola example earlier).

If both the POWER DOWN and IDLE modes must be used, the gate may be replaced with an ACT266 exclusive NOR with an open collector output. This circuit is shown in Figure 6.



*Power Management Techniques In The PSD3XX (Cont.)*  The I/O bit can be provided by either the PSD3XX or the controller itself. If the controller is used to provide the I/O bit, it must hold the correct value on the output even when in the idle or sleep mode, as the PSD3XX does. When the I/O bit is low, the POWER DOWN mode is enabled (a low on ALE and a LOW on the I/O bit will result in a high on  $\overline{CSI}$ ). When the I/O bit is high, the IDLE mode is enabled (a high on ALE and a high on the I/O bit will result in a high on  $\overline{CSI}$ ).

For all of the above circuits to operate correctly, the value of the RC network must be carefully calculated to insure proper operation in the normal mode. This means that under normal operation, CSI must never climb above 0.4 V, which will guarantee that it is always recognized by the PSD3XX as a low.

For example, the 68HC11 circuit shown in Figure 2 used the E signal from the controller to disable the PSD3XX. The E signal oscillates at 1/4 the frequency of the HC11's input clock. If an 8 MHz HC11 is used, the E signal will oscillate at 2 MHz. This results in an E signal clock period of 500 ns. During this 500 ns the E signal will be low for 250 ns. Thus, the RC network must be chosen to prevent the  $\overline{CSI}$  signal from climbing above 0.4 V for at least 250 ns. The equation below governs the voltage across the capacitor (V<sub>C</sub>), and thus the voltage present on the  $\overline{CSI}$  pin:

 $V_c = V_{cc}(1 - e^{-t/RC})$ 

where  $V_C$  is the voltage across the capacitor (which is the same as the  $\overline{CSI}$  pin),  $V_{CC}$  is the supply voltage, and t is the time in seconds after the output of the open collector gate switches from a low to an open circuit. Solving for RC we get:

$$RC = -t/ln(1-V_C/V_{CC})$$

In order to determine the minimum values for R and C, we must solve this equation for the point of time which is of interest. We must have  $V_C$  no greater than 0.4V at time t = 250 ns. Thus, with  $V_{CC} = 5$  V, the equation may be rewritten as follows:

An acceptable RC network for this case might be a resistor of 100K $\Omega$  and a capacitor of 30pF. These values will provide no margin for the circuit so some additional resistance or capacitance may be desired. Of course, larger values may be used without harming the circuit, they will just cause the low power mode to be entered more slowly. The case of leaving the low power mode is less critical, since the capacitor will discharge more quickly through the gate than it will charge up through the resistor. In the interest of minimizing power use by the circuit itself, it is best to use a larger resistor value and a smaller capacitor value, since this will cause less current to be sunk by the gate which drives the circuit.

Using this equation, it is possible to determine the RC value required for any controller and/or frequency. It is only necessary to determine the length of time that the RC will be required to hold the  $\overline{\text{CSI}}$  signal below 0.4 V and plug that value into the above equation.

If a more deterministic method is desired for placing the PSD3XX in the power down mode, a fully digital circuit may be implemented which uses very few additional components. This circuit is shown in Figure 7 for the 68HC11 controller.

This circuit performs the same function as the RC circuit described earlier, but does it digitally. The 74ACT164 is a shift register which is used in this example to detect when eight HC11 input clocks occur while the E signal remains low. In normal operation, no more than two clocks should occur without E transitioning from low to high, thus providing a clear to the ACT164. If the HC11 is stopped, the E signal will remain high until an interrupt is received, but the input clock continues to run freely. Thus, the shift register will shift in "one's" until the E signal goes high again. When the ACT164 has shifted eight times, the CSI signal will go high, placing the PSD3XX into the power down mode. The timing diagram corresponding to this circuit is shown in Figure 8.

## PSD3XX

#### **Application Note 016**

#### Power considerations in the PSD3XX

PSD3XX



#### *Power Management Techniques In The PSD3XX (Cont.)*

A similar circuit may be used for the 8031 family of controllers, and is depicted in Figure 9.

This circuit, like the others, detects when ALE stops toggling. Since up to 10 clocks may normally occur without an ALE pulse, a counter which can count to at least 11 is required in order to function properly. Thus, an 8-bit shift register like the one used with the HC11 will not work. In this case, a 74ACT191 is used to count 16 clocks prior to raising its MAX/MIN output high. A low on the ALE signal will load zero's into the counter and clear the MAX/MIN output. The MAX/MIN output is also used as the counter enable to prevent the counter from counting further after attaining the count of 16. The circuit shown will function with the IDLE mode of the 8031. If the POWER DOWN mode is used, an inverter must be inserted in the ALE signal path.

Other controllers, not listed here, may also have power down modes which may function with these circuits. Any controller which has some sort of external indication when the power down mode has been entered may usually be used to place the PSD3XX in its low power mode also.

# PSD3XX



#### *Power Management Techniques In The PSD3XX (Cont.)*

#### PAD Programming Techniques

The preceding section has described methods of using the power down capability of the PSD3XX with several microcontrollers. There are also techniques which may be utilized during programming of the device to further reduce power. These techniques can significantly reduce the power expended by the PSD3XX when it is in full operation.

The programmable logic section of the PSD3XX, called the PAD, provides much of its great flexibility and configurability. It is used to control the internal resources of the PSD3XX and can also be used to control external resources as well. The power use of the PAD varies greatly depending on how its product terms are programmed and used.

The PAD is illustrated in Figure 10. It is divided into two sections, called PAD A and PAD B. PAD A is responsible for generating the control and selection for the internal resources of the PSD3XX and utilizes 13 product terms to perform these functions. PAD B provides any external chip selection and logic replacement that is necessary for the system and has 27 product terms for this purpose. A single product term is functionally illustrated in Figure 11. Each of the PAD inputs and its complement is available to each of the 40 product terms of the PAD. Each of these inputs is connected to an n-channel transistor which is used to connect the entire line to ground when the input is in the appropriate state. A high on the input to the gate causes the transistor to turn on. When the device is programmed, each of these transistors may be left in place or may be functionally removed (programmed out) from the circuit. If all of the transistors are programmed out, the line is left connected only to the pull-up resistor which makes it always high. Thus, the output of the inverter is always low. If an equation such as:

/CSx = In#1 • /In#2

is programmed into the PAD, the output CSx must be high except when In#1 is high and In#2 is low. Thus, all of the transistors are programmed out except the ones connected to In#1 and In#2. This means that unless In#1 is high and In#2 is low, there will always be at least one of the two remaining transistors turned on, which in turn results in the CSx output being high. When the appropriate input condition is met, the remaining two transistors will turn off, which allows the output to become low.



4

PSD3XX

늧

#### *Power Management Techniques In The PSD3XX (Cont.)*

As can be seen in the figure, the product term expends very little power when all of the transistors are either programmed out or turned off. The only power used in this case is the result of the leakage current through the various off transistors, which is very low in CMOS technology. When one or more of the transistors is turned on, there will be current drawn through the pull-up resistor to ground. Therefore, the power used by a product term varies greatly according to the way it is programmed.

Experimental data has shown that a product term with all of the transistors programmed out draws approximately  $380\mu$ A less current at room temperature and 5.0 V V<sub>CC</sub> than a product term which has some active transistors. WSI's MAPLE software packages take advantage of this fact to reduce power as much as possible.

When the user intends to use some or all of the Port B pins as I/O signals, then they are not connected to the PAD in any way. Thus, the MAPLE software is free to program the unused PAD B product terms in any way. In MAPLE versions 4.03B and subsequent, the software automatically programs out all transistors in each unused product term, which can eliminate up to 24 product terms for Port B. This results in a power reduction of up to 9.1 mA.

If one or more of the Port C pins is programmed as an address or logic input, MAPLE is free again to program out all of the transistors in each unused PAD B product term dedicated to Port C. This can eliminate up to 3 additional product terms resulting in a power reduction of over 1 mA.

Finally, there are three product terms from PAD A which are dedicated to controlling the Port A Track Mode operation. If the Track Mode is not used in the application, these product terms may also be eliminated by MAPLE for a power reduction of over 1 mA.

The remaining ten product terms are the 8 EPROM select lines, the SRAM select line and the I/O port select line. These terms may not be eliminated by MAPLE without disrupting the operation of the device. But in a system which uses Port A and Port B as I/O or address outputs, and Port C as address or logic inputs, the total system power saving is 10.2 mA typical. The same methods may also be used in non-multiplexed microcontroller applications. In this case, Port A and Port B may be used as microcontroller data input pins, depending on whether the controller is 8- or 16-bit. As in the earlier cases, if the ports are used as data input pins, they are not connected to the PAD which allows MAPLE to program out the appropriate product terms.

Again, MAPLE 4.03B or a subsequent revision must be used to obtain this capability. If your software is an older revision, contact your local WSI regional sales office for a free update.

#### **EPROM Programming Techniques**

Like the PAD, the EPROM in the PSD3XX uses varying amounts of power depending on how it is programmed. When programmed to a one, an EPROM bit draws more current than when programmed to a zero. Thus, for minimum power usage it is best to have the majority of the EPROM programmed to zeros.

Unfortunately, the contents of the EPROM are fixed by the program and data requirements of the system and thus cannot be easily optimized for power. However, the user can program all unused sections of the EPROM to zeros. This will not substantially cut the power used by the PSD3XX under normal operation when EPROM accesses are being performed, but it will reduce the power consumption during periods when there is not a valid address on the bus because these invalid addresses will often point to unused EPROM locations. When an EPROM location is currently addressed, it is expending power even if the RD or PSEN signals are not actually enabling an output. Therefore, it is best that unused EPROM locations be filled with zeros so that power is minimized during these periods of invalid addresses. It should be noted that all power figures used in this application note as well as those specified in the PSD3XX data sheet are based on an average of 50% "ones" and 50% "zeros" contained in the EPROM. An EPROM location programmed to "ones" will draw approximately 1.5 mA of additional current over an EPROM location programmed to "zeros".

## PSD3XX

| Power<br>Management<br>Techniques<br>In The PSD3XX<br>(Cont.)<br>Summing<br>It All Up | An even better way to help minimize power<br>usage is to control the addresses which<br>appear on the bus when there is no valid<br>address being driven by the microcontroller.<br>The least power expense will be when this<br>unused address points to an area which<br>has no PSD3XX resource mapped into it.<br>This will result in no internal resource block<br>receiving a chip select and thus the least<br>amount of current will be drawn. The next<br>best approach is to have the unused<br>address point to an EPROM area<br>containing zeros. The next lowest power<br>would be to have the unused address point<br>to an EPROM area containing something<br>other than zeros. Finally, the highest power<br>will occur when the unused address points<br>to an SRAM location. | Since there is not much that can be done<br>about the address that is appearing at the<br>output of the microcontroller, the best that<br>can be done is to know what address the<br>controller will have active on its bus at<br>various non-operational times and insure, if<br>possible, that the PSD3XX's address map<br>maps that address into a desired range of<br>memory (preferably no memory at all). This<br>will truly minimize the power expended by<br>the PSD3XX during these times. |
|---------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                       | Using this information, we can calculate<br>the approximate typical power<br>requirements of the PSD3XX. Before we<br>can begin, we must know what the base<br>power of the PSD3XX is under the voltage                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | are being currently accessed. The current<br>drawn by the PSD3XX under these<br>conditions has been determined<br>experimentally to be 16 mA. To this current,<br>we must add additional current for the other<br>active product terms, SRAM access and<br>EPROM access.                                                                                                                                                                                                                            |
| Table 1.<br>Hypothetical                                                              | Characteristic                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Specification                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Hypothetical<br>System                                                                | PSD3XX Operational Frequency                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 2 MHz                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Requirements                                                                          | Port A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Address Output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                                                                                       | Port B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 4 Chip Select, 4 I/O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                                                       | Port C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Logic inputs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                                                                       | CSI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Configured for Auto. Power Down                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                                                       | V <sub>cc</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 5.0 V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                                                                       | Tomporature                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0500                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

Temperature Standby duty cycle

EPROM duty cycle

SRAM duty cycle

25°C

60%

30%

10%

# Power considerations in the PSD3XX

| Summing<br>It All Up<br>(Cont.) | The system is requiring only four of the 11<br>available chip select outputs. Therefore,<br>most of the PAD B product terms may be<br>programmed out. To determine how many<br>product terms we will be using, we must<br>look at the equations for the four chip                                                                                                                                                                                                                                                    | as logic inputs (A16, A17 and A18) and<br>therefore cannot be used as chip selects.<br>Since the rest of the Port pins are not used<br>as PAD outputs, the MAPLE software will<br>automatically program them out.                                                                                                                                                                                                                                                                                                                     |
|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                 | selects. Assume that the following equa-<br>tions are to be used:                                                                                                                                                                                                                                                                                                                                                                                                                                                    | If we do configure the chip selects to output<br>on PB[0:3], we must add 8 product terms to<br>the 10 used in calculating the base power                                                                                                                                                                                                                                                                                                                                                                                              |
|                                 | /CS#1 = /(A15 • A14 • RD + A13 • A12 • WR)                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | number. Using the current per product term                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                 | /CS#2 = /(/A18 + /A17)<br>/CS#3 = /(A16 • A18 + A17 • ALE)                                                                                                                                                                                                                                                                                                                                                                                                                                                           | of 380µA provided earlier, eight additional                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | product terms result in an additional 3.0 mA<br>of current.                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                 | /CS#4 = A17                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                 | In order to configure the system for the<br>lowest power usage, we must be sure that<br>we place these chip selects on the output<br>pins which will require the minimum<br>number of product terms to remain<br>active. Since the maximum number of<br>product terms required to generate the<br>above equations is only two, there is no<br>need to place these chip selects on Port B<br>pin 0,1,2 or 3 since these pins each have<br>four product terms. The lower power<br>configuration would place these chip | Experimental data has shown that accessing the SRAM results in an additional current expense of 31 mA above the base current. Also, accessing the EPROM draws an additional 0.5 mA over the base current. The standby current has been measured at 50 $\mu$ A. Finally, we must consider the additional current used by the frequency of operation. This is 3 mA per 1 MHz for a total of 6 mA, since the PSD3XX will be operating at 2 MHz. This provides us with all of the data that we need to calculate the total power usage of |

Table 2 can be used to calculate the EPROM access current, the SRAM access current and the standby current.

the PSD3XX in this system.

| Table 2.                     |
|------------------------------|
| Summary of<br>PSD3XX Current |
| Usage In                     |
| Hypothetical<br>System       |

| PSD3XX Block        | Current Used |
|---------------------|--------------|
| Base Configuration  | 16 mA        |
| PAD (as configured) | 3.0 mA       |
| EPROM               | 0.5 mA       |
| SRAM                | 31 mA        |
| Frequency Component | 6 mA         |
| Standby Current     | 50 μA        |

Now, summarizing further, the total EPROM access current is:

selects on Port B pin 4,5,6 and 7, where

above chip selects, #4, actually requires

could be placed on one of the Port C pins which have only one product term. However, all of Port C is used in this case

only one product term, meaning that it

only two product terms will be drawing power for each chip select. One of the

Base Current + PAD Current + EPROM Current + Frequency Component = 16 mA + 3.0 mA + 0.5 mA + 6 mA = 25.5 mA The total SRAM access current is:

Base Current + PAD Current + SRAM Current + Frequency Component = 16 mA + 3.0 mA + 31 mA + 6 mA

= <u>56.0 mA</u>

# Power considerations in the PSD3XX

| Summing<br>It All Up<br>(Cont.)   | Now we must account for the duty cycle of<br>the system to determine the total average<br>power for the PSD3XX. In order to apply<br>the duty cycle, we simply multiply each<br>power component by its duty cycle and add<br>them all together. The equation to perform<br>this is given below:<br>Total Current = $0.6(i_{SBY}) + 0.3(i_{EPROM})$<br>+ $0.1(i_{SRAM})$<br>where $i_{SBY}$ is the standby current, $i_{EPROM}$ is<br>the active EPROM current and $i_{SRAM}$ is the<br>active SRAM current. Plugging in the<br>numbers we developed earlier, the equation<br>becomes:<br>Total Current = $0.6 (50 \ \mu\text{A}) + 0.3$<br>(25.5 mA) + $0.1(56.0 \ \text{mA}) = 13.3 \ \text{mA}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | The average current drawn by the PSD3XX under the specified conditions of configuration, frequency and environment is therefore 13.3 mA. The peak typical current used by the PSD3XX is 54 mA while the SRAM is being accessed. The minimum current is 50 $\mu$ A, drawn by the PSD3XX while it is in the Power Down mode. This compares very favorably with the typical current usage of a fully discrete solution.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Typical vs.<br>Maximum<br>Gurrent | The typical and maximum current numbers<br>are both specified by most integrated circuit<br>manufacturers. Many designers are unsure<br>of what these parameters are and how they<br>relate to the power which will actually be<br>dissipated by the system. This is<br>compounded by the configurability of the<br>PSD3XX.<br>The maximum power numbers published in<br>most product specifications are usually<br>chosen as the number which will never be<br>exceeded by the device under any<br>circumstances, including variations in<br>processing, $V_{CC}$ and temperature. To truly<br>be a maximum number, all three of these<br>parameters must be at their worst cases<br>simultaneously, which is quite unlikely.<br>Therefore, power use will more likely follow<br>the typical values when the system is<br>actually running.<br>In the PSD3XX data sheet published by<br>WSI, two current values are published for<br>typical conditions and another two are<br>published for worst case conditions. These<br>two sets of numbers are used to specify<br>current use in two different PSD3XX<br>configurations. The lower numbers<br>represent the current drawn by the<br>PSD3XX while configured with 10 active<br>product terms. To arrive at the maximum<br>value for this configuration, we assume that<br>the programming of the device has not<br>changed, but we take the temperature,<br>voltage and processing to their worst case | conditions. These numbers are generated<br>again for the configuration of the PSD3XX<br>which has all 40 product terms active. To<br>determine the typical current drawn by the<br>PSD3XX in your system, it is best to use<br>the techniques presented in this application<br>note. All of the typical current values used<br>in this note are the result of careful experi-<br>mentation, and should parallel very closely<br>the values measured in your own system.<br>To extrapolate the worst case current for<br>your configuration from your calculated<br>typical value, you must add about 50% to<br>account for voltage, temperature and<br>process variation.<br>When calculating the worst case current for<br>your entire system it is usually best to use<br>the typical current numbers for all of the<br>components installed and then apply some<br>margin to allow for worst case conditions.<br>This is much more accurate than using the<br>worst case parameters for each<br>component since it is <i>extremely</i> unlikely<br>that <i>all</i> of the components used are<br>simultaneously at their worst case process<br>parameters, though they may all be at<br>worst case voltage and temperature.<br>Usually 20% margin above the typical<br>numbers will sufficiently cover the worst<br>case for the entire system.<br>Table 3 summarizes the typical current<br>numbers for the PSD3XX which can be<br>used when calculating the current used in<br>your own system. |

# **PSD3XX**

| Table 3.<br>Summary of | Base Current (10 product terms, SRAM and EPROM Unselected) | 16 mA        |
|------------------------|------------------------------------------------------------|--------------|
|                        | Additional Current per Product Term                        | 0.38 mA      |
| PSD3XX                 | Additional Current for SRAM Access                         | 31 mA        |
| Typical                | Additional Current for EPROM Access                        | 0.5 mA       |
| <i>Current</i>         | Additional Current for Frequency Effects                   | 3 mA/MHz     |
| Usage                  | Additional Current for Voltage > 5V                        | 0.85 mA/0.1V |
|                        | Standby Current                                            | 50 μA        |

#### Conclusion

The PSD3XX is a very important device in the design of compact, low-power systems. It provides a cost effective minimum part count solution for a typical microcontroller system. It also provides a very low power solution for those designs which are handheld and/or battery operated. As the PSD3XX family grows and evolves, more innovations will be presented in terms of integration and power usage. The new low power PSD3XX family will be introduced soon, providing the designer with an even lower power solution. Until then, use of the techniques described in this note will provide a minimum power solution for your microcontroller system.

# Security of Design in the PSD3XX

By Oudi Moran – WSI

| Introduction               | The PSD3XX is a family of field program-<br>mable and UV erasable microcontroller<br>peripherals that have the ability to interface<br>to virtually any microcontroller without the<br>need for external glue logic.                                                                                                                                                                                                                                                                                                                                               | Since the PSD3XX is a field programmable device, its contents may be read by an I.C. programmer, decompiled and copied by a competitor.                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                            | Any PSD3XX family member is a complete<br>microcontroller peripheral solution with<br>Memory (EPROM, SRAM), Logic, I/O Ports<br>and a Security bit on chip.<br>In today's competitive business environ-<br>ment, where the cost of the product and its<br>quick introduction to market are the most<br>important factors for success, some<br>companies tend to copy a competitor's<br>design. By doing so, they can save<br>development time which can reduce their<br>engineering cost and eventually reduce the<br>product's price and its introduction time to | Obviously, it is an undesirable situation for<br>the EPROM, PAD and configuration data of<br>the PSD3XX to fall into the hands of a<br>competitor. To prevent this, the PSD3XX<br>device implements a security "fuse" or<br>programmable bit feature to protect its<br>contents from unauthorized access and use<br>by a competitor.<br>Uploading the programmed data from<br>EPROM, PAD, ACR and NVM port config-<br>uration sections of a secured PSD3XX<br>device is disabled by the security bit<br>(if turned ON). The RAM of the programmer<br>(after trying to upload a secured PSD3XX |  |  |
|                            | the market.<br>This is true mainly for the consumer and<br>commodity product markets where micro-<br>controllers are widely used. The PSD3XX,<br>as the primary microcontroller peripheral,<br>contains all the important code and<br>architectural data that a potential competitor<br>may want to copy.                                                                                                                                                                                                                                                          | device) will contain invalid random data.<br>A secured PSD3XX device will function<br>properly in the system – the microcontroller<br>will be able to access the EPROM, SRAM,<br>PAD and the I/O ports but any attempt to<br>read or verify the contents of a secured<br>PSD3XX by external hardware will fail.                                                                                                                                                                                                                                                                               |  |  |
| Use of the<br>Security Bit | PSD3XX devices contain non-volatile<br>configuration bits to enable the user to set<br>and configure the device to the proper<br>operational mode. The configuration bits will<br>configure the device to interface success-<br>fully with the microcontroller and also<br>configure the PSD3XX I/O Ports. The<br>configuration bits are programmed during<br>the programming phase and cannot be<br>accessed in operational mode.                                                                                                                                 | <ul> <li>2) The NVM section of the PSD3XX device contains port configuration bits for proper set up of Ports A, B and C.</li> <li>PSD3XX devices use the security bit to prevent unauthorized access to the configuration data inside. Since the security bit is part of the ACR global configuration bits section, it can be programmed in the same manner as all other configuration bits.</li> </ul>                                                                                                                                                                                       |  |  |
|                            | <ul> <li>During programming the configuration bits are programmed as two separate sections:</li> <li>1) The ACR section of the PSD3XX device contains global configuration bits for proper microcontroller interface. The security bit resides as an individual configuration bit in the ACR section of the device.</li> </ul>                                                                                                                                                                                                                                     | All ACR and NVM configuration bits of the PSD3XX are non-volatile, so their contents will not be erased or corrupted during the power down mode of the device (when the PSD3XX is deselected with $\overline{\text{CSI}}/\text{A19} =$ High) or during power down when V <sub>CC</sub> is removed.                                                                                                                                                                                                                                                                                            |  |  |

#### Application Note 018

## Security of Design in the PSD3XX By Oudi Moran – WSI

**PSD3XX** 

| Use of the   | The security configuration bit is user                    | setting the security bit, it is impossible to                                |
|--------------|-----------------------------------------------------------|------------------------------------------------------------------------------|
| Security Bit | programmable and UV erasable as well, so                  | read them by using external equipment                                        |
| (Cont.)      | a secured part can be erased completely                   | (except by the microcontroller in the system                                 |
| (00111.)     | and be reprogrammed (only if the device is                | where the PSD3XX designed in). This is                                       |
|              | in a windowed package).                                   | because the external equipment will lack                                     |
|              |                                                           | information about the address mapping of                                     |
|              | Setting the security bit will lock all the                | the eight EPROM blocks, SRAM and I/O                                         |
|              | contents of the PAD, ACR global config-                   | ports in the memory map of the                                               |
|              | uration bits, and NVM port configuration                  | microcontroller and the unknown status of                                    |
|              | bits. By setting the security bit the device              | the global and I/O port configuration bits.                                  |
|              | cannot be entered into Initialization and                 |                                                                              |
|              | Override mode (resets the device and                      | Even if an unauthorized user figures out the                                 |
|              | enters it to a known default configuration                | configuration of the part by knowing what                                    |
|              | before activating the individual read mode                | microcontroller is interfaced (ALE polarity,                                 |
|              | for each section). Any attempt afterwards to              | what type of read and write signals, etc.)                                   |
|              | enter the device to DIRECT mode for                       | and gets data out of the PSD3XX (after                                       |
|              | uploading or programming will fail. Setting               | applying address and control signals to the                                  |
|              | the security bit prevents a programmer from               | device), the user will have no idea where it                                 |
|              | directly accessing the various sections of<br>the device. | came from: EPROM, SRAM, I/O Port                                             |
|              | the device.                                               | Register, Page Register, etc. This                                           |
|              | Even they shall be EPROM SPAM and 1/0                     | effectively renders the data useless.                                        |
|              | Even though the EPROM, SRAM and I/O                       |                                                                              |
|              | port contents are not directly disabled by                |                                                                              |
| Setting the  | <b></b>                                                   |                                                                              |
|              | The security configuration bit is called                  | addresses of the object file created after                                   |
| Security Bit | CSECURITY.                                                | compilation. (See Security Bit File Location                                 |
|              |                                                           | section of this document).                                                   |
|              | If CSECURITY = 0, it means security is off                |                                                                              |
|              | (security bit is not set and its value will be '1'        | If Setting of the security bit is done in the                                |
|              | in the object file).                                      | programming software (Third party pro-                                       |
|              |                                                           | gramming software or WSI Mappro                                              |
|              | If CSECURITY = 1, it means security is on                 | programming software), the user should                                       |
|              | (security bit is set and its value will be '0' in         | program and verify the device using a                                        |
|              | the object file).                                         | Maple generated object file (with security                                   |
|              | O states the second to bit and estimation the             | option OFF) and then set the security ON by                                  |
|              | Setting the security bit and activating the               | using a separate programming software                                        |
|              | security mode can be done in two different                | command.                                                                     |
|              | ways:                                                     | Come third party programmer many                                             |
|              | 1) Duturning acquirity ONI in the config                  | Some third party programmer manu-<br>facturer's software will load the Maple |
|              | 1) By turning security ON in the config-                  | generated object file but mask the security                                  |
|              | uration menu of Maple development<br>software.            | bit before programming the device. In that                                   |
|              | sonware.                                                  | case the user will have to set the security                                  |
|              |                                                           | bit (if necessary) by using a separate                                       |
|              | 2) By setting the security in the                         | command in the programming software                                          |
|              | programming software (done after the                      | menu.                                                                        |
|              | device is fully programmed and verified).                 | mona.                                                                        |
|              | device is faily programmed and vermed).                   |                                                                              |
|              |                                                           |                                                                              |
|              | Using Maple development software to turn                  |                                                                              |

May, 1993

security ON gives the security bit the value '0', and will integrate it in one of the ACR

### Security of Design in the PSD3XX By Oudi Moran – WSI

| Security<br>Bit File<br>Location | The object file created by compilation with<br>Maple software is an Intel Intelec format,<br>compatible file.                                                                                                                                                                                                                          | by Mappro WSI programmer interface<br>software as SECA = 1).<br>The security bit of PSD302/312 resides in                                                                                                                                                                                                                                                                                                    |
|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                  | The programming algorithm defines the<br>address scrambling that translates the file<br>addresses to device addresses (the address<br>that the device "sees" on its address pins<br>during programming). By looking at a<br>screen dump or a hard copy of the object<br>file the user can determine the status of the<br>security bit. | data bit #1 of file address 10253h. This<br>address contains three configuration bits<br>that reside in data bits $0 - 3$ (bit 3 is<br>reserved for future usage). This address<br>can have any value between 0 and F. If this<br>address has a value XX1X (where X can be<br>either 0 or 1), the security bit is OFF<br>('1' value means an unprogrammed bit) and<br>CSECURITY = 0 (displayed by Mappro WSI |
|                                  | The security bit of the PSD301/311 resides<br>in data bit #1 of file address 81D3h. This<br>address contains three configuration bits<br>that reside in data bits $0-2$ , so this address<br>in the file can have any value between 0<br>and 7.                                                                                        | <ul> <li>CSECORITY = 0 (displayed by Mappio WSI programmer interface software as SECA = 0). If this address has a value XX0X, the security bit is ON and CSECURITY = 1 (displayed by Mappro WSI programmer interface software as SECA = 1).</li> </ul>                                                                                                                                                       |
|                                  | If this address has a value X1X (where X can be either 0 or 1), the security bit is off ('1' value means an unprogrammed bit) and CSECURITY = 0 (displayed by Mappro WSI programmer interface software as SECA = 0).                                                                                                                   | If users do not want to look for the security<br>bit status in the object file, they can call<br>MAPPRO programming software from the<br>main menu of MAPLE, Load the RAM with<br>the object file and Display the ACR<br>configuration bits status on the screen.                                                                                                                                            |
|                                  | If this address has a value X0X, the security bit is on and CSECURITY = 1 (displayed                                                                                                                                                                                                                                                   | The value of SECA will indicate the status of<br>the security bit (SECA = 0 means security is<br>OFF, SECA = 1 means security is ON).                                                                                                                                                                                                                                                                        |
| Summary                          | The PSD3XX family of programmable<br>microcontroller peripheral devices provides<br>security of design not readily available in<br>conventional PLDs and EPROMs.                                                                                                                                                                       | Though not entirely fool-proof, the security<br>bit feature helps make it more cost effective<br>for competitors to design their own<br>hardware instead of trying to copy systems<br>that alroach write                                                                                                                                                                                                     |

that already exist.

# The PSD311 simplifies an eight wire cable tester design and increases flexibility in the process By Timothy E. Dunavin, Antec – Anixter Mfg. and Karen S. Spesard, WSI

| Abstract                             | With the ever increasing complexity of<br>wiring networks and cables to match a wide<br>variety of computer and telecommunication<br>systems, a means of testing them becomes<br>a necessity. The wire tester design<br>described below is a simple yet effective                                                                                                                                                                                                                                                                                                                   | design which uses the Motorola 68HC11<br>and WSI PSD311 pair to create a system<br>that insures 8-wire cables are wired<br>properly, and at the same time offers a<br>substantial increase in design flexibility<br>over alternative hardware solutions.                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction                         | More and more microcontroller and<br>microprocessor designers are trying to<br>design integrated core-based systems with<br>the intention of being able to easily<br>configure their systems to fit a wide variety<br>of product applications. The problem is that<br>when these applications require new or<br>changing features such as expanding I/Os<br>or address maps, they may find their<br>designs are not flexible enough to                                                                                                                                              | can be re-configured for other applications<br>using the same core design. Also, the<br>PSD3XX product family can enhance<br>microcontroller-based systems in other<br>ways. For instance, it can improve system<br>integration resulting in lower system costs,<br>and it can significantly shorten time to<br>market resulting in increased revenues and<br>profits.                                                                                                                                                                                                                                                                                                                     |
|                                      | accommodate the new requirements,<br>forcing a lengthy and expensive redesign<br>anyway.<br>A solution to this problem is to design in<br>user-configurable programmable peripheral<br>products which are flexible enough to<br>accommodate future design revisions<br>without the need for board relayout. The<br>PSD3XX family from WSI, Inc., fits this<br>profile exactly in that the products can be<br>tailored to a specific application and then                                                                                                                            | In the cable tester system in which the<br>PSD311 was used with the 68HC11, the<br>PSD311 integrates address decoding,<br>latches, 32K x 8 EPROM, and 2K x 8<br>SRAM all into a one-chip user-configurable<br>microcontroller peripheral. It also replaces<br>the two ports lost by the 68HC11 to extend<br>program and data memory outside the<br>MCU with two additional configurable 8-bit<br>I/O ports, and adds a third 3-bit port, while<br>easily enabling still further port expansion.                                                                                                                                                                                            |
| The Cable<br>Tester System<br>Design | The cable tester described below operates<br>by sending a known bit pattern through the<br>cable under test and checking the bit<br>pattern at the other end. The hardware<br>configuration utilized to achieve this<br>function is shown in Figure 1.<br>Note that there are very few components<br>overall in the design. The core contains<br>just the 68HC11 microcontroller from<br>Motorola, the PSD311 Programmable<br>Peripheral with Memory from WSI<br>and a few other key components including<br>a keypad, LCD display, and an optional<br>RS232 communications device. | Also note that the interconnections<br>between the 68HC11 and PSD311 are<br>direct and require no "glue logic". That<br>means that no external latches are needed<br>to demultiplex the multiplexed address and<br>data bus from the 68HC11. And, no other<br>external logic is needed to generate the<br>address mapping for the on-board EPROM<br>and SRAM and to select external<br>peripherals, or create the control signal<br>interface. The PSD311 already<br>incorporates these features internally,<br>thereby simplifying the design consider-<br>ably. In fact, the PSD311's architecture, as<br>shown in Figure 2, specifically includes<br>32K x 8 mappable EPROM for program |



### Figure 1. PSD311/68HC11 Implementation in the Cable Tester Design

May, 1993

418

Application Note 019

Philips Semiconductors Microcontroller Peripherals

The

PSD31

-

S

implifies

an

eight wire cable tester design and increases



| -                                               | -                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                  |
|-------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| The Cable<br>Tester System<br>Design<br>(Cont.) | storage, 2K x 8 mappable SRAM for data<br>storage (or 16K x 16 EPROM and 1K x 16<br>SRAM, if using the similar PSD301<br>configured to interface to x16 micros) three<br>highly configurable I/O ports, a<br>programmable address decoder, and chip<br>select logic.<br>In this design, the reconstructed port space<br>of the PSD311 is used to add a keypad                                                       | and an LCD display to the system, as well<br>as additional output control and input lines<br>with an 8-bit latch and an 8-bit buffer/line<br>driver. Besides these components, the<br>completed cable tester design also includes<br>an undervoltage sensing circuit for generat-<br>ing a reset signal and an encoder for inter-<br>facing to the keypad.       |
| Interfacing<br>To The PSD311                    | Not only does the PSD311 interface to the<br>68HC11 simply and directly because of its<br>internal latches and programmable control<br>signals – as it does with any 8-bit microcon-<br>troller – it also facilitates easy interfacing to<br>other components. (The PSD301 interfaces<br>to any 8-or 16-bit microcontroller.) This is                                                                               | "WOM" (Write Only Memory), its $R/\overline{W}$<br>line is tied to ground to free an I/O pin of the<br>PSD311 for other purposes. To free up Port<br>A completely on the PSD311, an<br>alternative approach would have been to<br>connect the LCD directly to the 68HC11.<br>To expand the I/O capabilities of the system                                        |
|                                                 | possible because of its three I/O ports and<br>the Programmable Address Decoder (PAD)<br>which offer unsurpassed flexibility. The PAD<br>block diagram is shown in Figure 3.                                                                                                                                                                                                                                        | further, two port pins from the PSD311 are<br>used with a 74HC574 and a 74HC541 to<br>create 8 additional inputs and 8 additional<br>latched outputs, both at the same address.                                                                                                                                                                                  |
|                                                 | For instance, the no "glue-logic" interface of<br>the keypad in the system is accomplished<br>by using a 74C922 encoder in conjunction<br>with the PAD section of the PSD311. The<br>PAD is useful because the Data Available<br>(DA) line of the 74C922 is a logic "1" when<br>a key is pressed, and the signal must be<br>inverted before it reaches the /IRQ input of<br>the 68HC11. Connecting the encoder's DA | (This is shown in Figure 1.) The PSD311's chip select outputs from ports B and C are derived from the addresses, DS strobe, and R/W signal available as inputs into the PAD. These chip selects will enable data to be latched to the outputs or enable input data onto the extended address/data bus from the outside world, imitating the capability of a PIA. |
|                                                 | line to the PSD311's PC2 pin and<br>configuring it to be a general-purpose logic<br>input enables the signal to be inverted<br>inside the PAD. The inverted signal is then<br>"outputed" on PC1 which is configured as a                                                                                                                                                                                            | The chip select equation for the output latch<br>74HC574, is decoded from the upper<br>address byte, the DS/E signal, and the<br>active low R/W signal as follows:                                                                                                                                                                                               |
|                                                 | chip select and routed to /IRQ. (See Port C<br>Configuration and Chip Select Equation in                                                                                                                                                                                                                                                                                                                            | /CS8 = /A1 <u>5</u> • /A14 • A13 • /A12 • DS •<br>/R/W.                                                                                                                                                                                                                                                                                                          |
|                                                 | Appendix A.) This simple internal<br>manipulation inside the PSD311 helps<br>reduce the number of components in the<br>system. By connecting the 74C922 outputs<br>directly to PE0-PE3 on the 68HC11, reading<br>of the data is straightforward.                                                                                                                                                                    | The resulting latched address is \$2000H with DS = 1 and $R/W = 0$ . The chip select equation for the input driver, 74HC541, is th same, because the address is the same (\$2000H), except that $R/W$ is active high. So, this equation becomes:                                                                                                                 |
|                                                 | The display used in the system is a 16<br>character by 2 line dot matrix LCD module.<br>The interface to the LCD display is handled                                                                                                                                                                                                                                                                                 | /CS9 = /A <u>15</u> • /A14 • A13 • /A12 • DS •<br>R/W.                                                                                                                                                                                                                                                                                                           |
|                                                 | by mapping the data bus directly to Port A<br>of the PSD311, which is configured pin-by-<br>pin to be general-purpose I/O. The control<br>logic for the LCD is handled through two<br>pins on Port B: PB0 and PB1, which are<br>also configured to be general-purpose I/O.                                                                                                                                          | The PSD311 simplifies the interface to the program and data memory, external peripherals, and I/O ports in the system by integrating the address decoder internally. This is illustrated with the direct interconnection between the microcontroller and other peripherals and the PSD211 without the                                                            |

peripherals and the PSD311, without the

need for a PLD or other logic.

(See Ports A and B Configuration in

Appendix A.) With the display used as a





| Interfacing<br>To The PSD311<br>(Cont.) | The PAD enables the 8 blocks of 4K bytes<br>EPROM (256K bits) to be located<br>anywhere within the available address<br>space – in this case, the address space of<br>the 68HC11 is 64K bytes. So, the EPROM<br>memory is split into two segments of 16K<br>bytes EPROM each, separated by the 512<br>bytes of the internal E2PROM on the<br>68HC11. This means that the first 4<br>EPROM blocks are mapped contiguously,<br>as well as the last 4 EPROM blocks.<br>Here, the program memory (6000H-9FFFH:<br>EPROM2, and C000H-FFFFH: EPROM1)<br>is allocated to the upper portion of address<br>space.<br>The data or SRAM memory, on the other<br>hand, is allocated to the lower portion of | address space and is partitioned into<br>two segments: one segment containing the<br>SRAM internal to the 68HC11 (256 bytes)<br>and the other containing the SRAM<br>internal to the PSD311 (2K bytes). The<br>SRAM in the PSD311 is mapped via the<br>address decoder to location 5000H-5FFFH,<br>respectively.<br>Data direction and data registers of the<br>PSD311's two ports are paired and<br>accessed via an offset from a configurable<br>I/O port mapped base address, such as<br>4000H in this cable tester design. This<br>enables 16-bit data instructions to access<br>the two I/O ports together, which in turn<br>reduces both the Load and Store times<br>during program execution. |
|-----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Benefits<br>of the PSD311               | Board layout of the cable tester design was greatly simplified with the PSD311. In fact, when pin 1 of the PSD311 is criented 180                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | that power was reduced by at least 30%.<br>This translates into requiring a smaller                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Usage In<br>System                      | when pin 1 of the PSD311 is oriented 180<br>degrees from pin 1 of the 68HC11 in the<br>PLCC package, port B of the 68HC11 is<br>directly across from the AD8-AD15 pins of<br>the PSD311. This positioning enables close<br>layout of the two parts, greatly reducing<br>costs due to less board space.                                                                                                                                                                                                                                                                                                                                                                                          | power supply and a further reduction in cost.<br>The flexibility of the PSD311 in the cable<br>tester design is also an advantage when<br>design changes need to be made quickly.<br>Since the I/O ports, PAD, control signals,<br>and EPROM are all programmable, the part                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                                         | Additional space is saved by using the latch<br>and buffer for general-purpose I/O instead<br>of the larger and more expensive PIA. And                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | just needs to be reprogrammed when the<br>configuration or program memory for the<br>entire system needs modifying.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                         | other I/O port lines are not sacrificed by<br>using the multiplexed address/data bus<br>instead of the Serial Peripheral Interface of<br>the 68HC11.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | For instance, the current system has ten<br>I/O, eleven input, and eleven output lines<br>remaining. This can change if other<br>variables need to be stored or other<br>peripherals need to be accessed. To                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                                         | In fact, board space is estimated to have<br>been reduced by more than 50% over the<br>alternative cumbersome design because of<br>the PSD311 positioning on the PC board,<br>its port expansion capabilities, and of<br>course, the number of parts it replaces:<br>including a 256K EPROM, a 16K SRAM, a<br>latch, a decoder, and other miscellaneous<br>CMOS logic.                                                                                                                                                                                                                                                                                                                          | avoid relaying out another board to<br>accommodate these changes, the PSD311<br>may be able to be reconfigured to easily<br>handle them. Also, if more features and/or<br>capabilities in EPROM are required, the<br>PSD312 and PSD313 with 512Kbits (64K x<br>8) and 1Mbits (128K x 8) EPROM, respec-<br>tively, are available in the same package<br>and pinout.                                                                                                                                                                                                                                                                                                                                   |
|                                         | A benefit of parts reduction is lower CMOS<br>power consumption that results from an<br>integrated single-chip CMOS peripheral/<br>memory solution. By analyzing the power<br>that would have been consumed with the<br>alternative design and comparing that<br>against the PSD311 solution, it was found                                                                                                                                                                                                                                                                                                                                                                                      | The PSD311 also provides additional SRAM<br>beyond the limited amount that may be on<br>the microcontroller being used.<br>This provides obvious benefits including<br>more scratchpad RAM for such uses as<br>storing cable "signatures" and system tests<br>that can be downloaded for diagnostic                                                                                                                                                                                                                                                                                                                                                                                                  |

purposes.

| Benefits<br>of the PSD311<br>Usage in<br>System<br>(Cont.) | But other benefits not readily seen are also<br>important. For product designs that have a<br>short life cycle and are "pushed" to go to<br>market quickly, the additional SRAM gives<br>the designer the option of writing the code<br>in a high-level language such as "C",<br>without the worry of running out of variable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | storage space. The capability of writing<br>software in "C" could speed up the software<br>development cycle, thereby reducing time-<br>to-market!                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
|------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| <i>Configuring and<br/>Programming<br/>the PSD311</i>      | All of the control logic, address mapping,<br>and port configurations for the PSD311 are<br>handled during device configuration as part<br>of WSI's easy-to-use, menu-driven PSD<br>MAPLE software program, which is<br>included in the PSD-SILVER or PSD-GOLD<br>software development package. See<br>Appendix A for the PSD311 configuration<br>used in this application.<br>After the configuration for the PSD311 has<br>been determined and "Save"d, the hex file<br>that is needed for programming the<br>PSD311 is created. That is done during                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | "Compile". "Compile" reads the code writter<br>for the microcontroller (in Intel hex format)<br>and concatenates or merges it with the<br>PSD311 configuration data to produce the<br>desired output file for downloading to a<br>programmer for programming.<br>That is all there is to programming the<br>PSD311 which is now supported on<br>industry-standard programmers like the<br>Data I/O, BP Microsystems, Bytek, and<br>Logical Devices programmers as well as<br>the low-cost WSI MagicPro programmer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| The 68HC11/<br>PSD311 System<br>Software                   | The software for the 68HC11 was written<br>with a word processor and assembled using<br>a cross assembler. A portion of the cable<br>tester design code which is programmed<br>into the PSD311 is listed in Appendix B.<br>Here the register and RAM memory loca-<br>tions are set up within the first 64 clock<br>cycles from reset of the 68HC11 and<br>located at 0000H to enable easy Direct<br>Addressing and Bit manipulations of often<br>used registers.<br>Initialization of the Option Register,<br>Timer prescaler, Stack and Serial<br>Communications Interface complete the<br>basic set up for the 68HC11 operation.<br>Other initialization operations include: Ports<br>A and B of the PSD311 which are set up as<br>outputs for display control and data transfer<br>operations, and the LCD display which is<br>set up to display the first screen. Final<br>initialization is achieved by setting several<br>internal registers and clearing any<br>pending interrupts. Now, the IRQ mask bit<br>can be cleared and the main program loop<br>entered. | Included in the code is a demonstration of<br>some useful routines which will illustrate<br>how to easily work with the Latch and<br>Buffer expansion from the 68HC11/<br>PSD311. Remember that these extended<br>addresses off the 68HC11 can be accessed<br>in several ways. The example code shown<br>uses the Bit Set and Bit Clear instructions<br>in the indexed addressing mode. With<br>these Bit Set and Bit Clear instructions, ar<br>additional register should be set up in the<br>internal RAM, not on the latched (write-<br>only) address, so the<br>instructions will function properly. Data can<br>then be manipulated and stored as a<br>complete byte to the latch enabling data to<br>be read and the current value in the latch to<br>be checked. (Bit manipulation on the<br>latched addresses using the indexed<br>addressing mode will result in a correct<br>bit change. However, the rest of the byte<br>will be unusable as data on the bus will be<br>scrambled at the rising edge of the chip<br>select signal.) The latch and buffer<br>expansion keeps software algorithms<br>simple. |  |

| <i>The 68HC11/<br/>PSD311 System<br/>Software<br/>(Cont.)</i> | Regarding the software for the keypad, no<br>debounce software is necessary because<br>the 74C922 has a built in debounce circuit.<br>Actually, direct access from Port E to the<br>keypad data and the AND instruction allows<br>easy compare and execution of the correct<br>routine.                                                                                                                                                                                                                                                                                                                                                                                  | The remaining subroutines in the program<br>are straightforward and basic to most<br>microcontrollers and microprocessors.<br>Those used by the 68HC11 are found in<br>previously published handbooks and<br>articles which can be obtained through<br>your local Motorola sales office.                                                                                                                                                                                                                                                                                                                                                               |
|---------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Putting the<br>System to<br>Work                              | The 68HC11/PSD311 cable tester design<br>could be expanded very easily with<br>software to learn many different wiring<br>configurations and to check several cables<br>against a good one. Its usefulness can also<br>be increased by making it battery operated<br>for field use because of the low current<br>draw of the tester.                                                                                                                                                                                                                                                                                                                                     | The cable tester, as designed, will display<br>the test results and step through the<br>program to show the pin by pin connections<br>of the cable. Results are then stored and<br>later fed into a computer through the<br>RS232 communications port of the tester.                                                                                                                                                                                                                                                                                                                                                                                   |
| Summary                                                       | Requirements for microcontroller-based<br>designs are continually changing and to be<br>able to adapt to these changes means<br>being flexible. Of course, flexibility in<br>hardware is sometimes hard to achieve,<br>while flexibility in software is mostly a<br>given. One of the goals of the PSD3XX<br>family of products is to bridge the gap in<br>flexibility between hardware and software.<br>By that, it is meant that hardware will not be<br>a gating item when developing a new<br>design that needs to be introduced to<br>market quickly. And the PSD311, as<br>illustrated in this cable tester design,<br>addresses that issue perfectly by providing | a user-configurable peripheral solution for<br>hardware designers. So, if an application is<br>modified and the I/O configuration<br>changes, or design fixes are required, the<br>P.C. board does not have to be<br>re-engineered. The PSD3XX can just be<br>reprogrammed to reflect the new changes.<br>The flexibility provided by the PSD311<br>solution in this design is crucial in that it<br>enabled development to be completed<br>quickly and successfully using a "core"<br>approach which can handle many different<br>cable applications, including applications<br>for telephone interconnections, printers,<br>and local area networks. |

#### Appendix A. PSD311 Part Configuration Listed in .SV1 File

ALIASES A16/CS8 = CS8A17/CS9 = IRQA18/CS10 = DAA19/CSI = CSI GLOBAL CONFIGURATION Address/Data Mode: МΧ Data Bus Size: 8 CSI/A19: CSI Reset Polarity: LO ALE Polarity: ΗI WRD/RWE: RWE A16-A19 Transparent or Latched by ALE: т Using different READ strobes for SRAM and EPROM: N \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* \*\*\*\*\* PORT A CONFIGURATION (Address/IO) Bit No. Ai/IO. CMOS/OD. 0 IO CMOS IO 1 CMOS 2 IO CMOS 3 IO CMOS 4 IO CMOS 5 IO CMOS 6 IO CMOS 7 10 CMOS PORT B CONFIGURATION CMOS/OD. Bit No. CS/IO. 0 IO CMOS 1 10 CMOS 2 IO CMOS 3 IO CMOS 4 IO CMOS 5 IO CMOS 6 10 CMOS 7 CS7 CMOS CHIP SELECT EQUATIONS /CS7 = /A15 \* /A14 \* A13 \* /A12 \* E \* R/W PORT C CONFIGURATION Bit No. CS/Ai. 0 CS8 CS9 1 2 A18 CHIP SELECT EQUATIONS /CS8 = /A15 \* /A14 \* A13 \* /A12 \* E \* / R/W /IRQ = DA\*\*\*\* ADDRESS MAP A A A A A A A A SEGMT SEGMT EPROM EPROM File Name 19 18 17 16 15 14 13 12 11 STRT STOP START STOP ES0 N X N N O 1 1 O N 6000 6FFF 6000 6fff BASE301.OBJ ES1 N X N N 0 1 1 1 N 7000 7FFF

| ndix A.<br>1 in .Sl                                                 |                                              |                                  |                                      |                            |                  | nfi                   | gur                   | atic                  | n                |                                      |                                      |                              |                              |                                                          |
|---------------------------------------------------------------------|----------------------------------------------|----------------------------------|--------------------------------------|----------------------------|------------------|-----------------------|-----------------------|-----------------------|------------------|--------------------------------------|--------------------------------------|------------------------------|------------------------------|----------------------------------------------------------|
| ES2                                                                 | N                                            | x                                | N                                    | N                          | 1                | 0                     | 0                     | 0                     | N                | 8000                                 | 8FFF                                 |                              |                              |                                                          |
| ES3                                                                 | N                                            | x                                | N                                    | N                          | 1                | 0                     | 0                     | 1                     | N                | 9000                                 | 9FFF                                 |                              |                              |                                                          |
| ES4<br>ES5<br>ES6<br>ES7<br>RS0                                     | N<br>N<br>N<br>N                             | X<br>X<br>X<br>X<br>X            | N<br>N<br>N<br>N<br>N                | N<br>N<br>N<br>N           | 1<br>1<br>1<br>0 | 1<br>1<br>1<br>1<br>1 | 0<br>0<br>1<br>1<br>0 | 0<br>1<br>0<br>1<br>1 | N<br>N<br>N<br>O | C000<br>D000<br>E000<br>F000<br>5000 | CFFF<br>DFFF<br>EFFF<br>FFFF<br>57FF | c000<br>d000<br>e000<br>f000 | cfff<br>dfff<br>efff<br>ffff | BASE301.OBJ<br>BASE301.OBJ<br>BASE301.OBJ<br>BASE301.OBJ |
| CSP                                                                 | N                                            |                                  |                                      | N                          |                  |                       |                       |                       | 0                |                                      | 47FF                                 |                              |                              |                                                          |
| CDATA<br>CADDI<br>CRRWI<br>CA19,<br>CALE<br>CRESI<br>COMB,<br>CADDI | A<br>RDAT<br>R<br>/ (/C<br>ET<br>/SEP<br>HLT | sI)                              |                                      | 0<br>1<br>0<br>0<br>0<br>0 | ***              | ***                   | ***                   | ***                   | * E              | ND **:                               | ******                               | *****                        | ******                       | ****                                                     |
| CPAF?                                                               |                                              |                                  | ==                                   | 0                          |                  |                       |                       |                       |                  |                                      |                                      |                              |                              |                                                          |
| CPAF<br>CPAF<br>CPAF<br>CPAF<br>CPAF<br>CPAF<br>CPAF                | L [1<br>L [2<br>L [3<br>L [4<br>L [5<br>L [6 |                                  | 0<br>0<br>0<br>0<br>0<br>0<br>0<br>0 |                            |                  |                       |                       |                       |                  |                                      |                                      |                              |                              |                                                          |
| CPACC<br>CPACC<br>CPACC<br>CPACC<br>CPACC<br>CPACC<br>CPACC         | DD [<br>DD [<br>DD [<br>DD [<br>DD [<br>DD [ | 1]<br>2]<br>3]<br>4]<br>5]<br>6] | = ()<br>= ()<br>= ()                 | )<br>)<br>)<br>)           |                  |                       |                       |                       |                  |                                      |                                      |                              |                              |                                                          |
| CPBF<br>CPBF<br>CPBF<br>CPBF<br>CPBF<br>CPBF<br>CPBF                | [1]<br>[2]<br>[3]<br>[4]<br>[5]<br>[6]       |                                  | 1<br>1<br>1<br>1<br>1                |                            |                  |                       |                       |                       |                  |                                      |                                      |                              |                              |                                                          |
| CPBCC<br>CPBCC<br>CPBCC<br>CPBCC<br>CPBCC<br>CPBCC<br>CPBCC         | DD [<br>DD [<br>DD [<br>DD [<br>DD [<br>DD [ | 1]<br>2]<br>3]<br>4]<br>5]<br>6] | = ()<br>= ()<br>= ()<br>= ()         | )<br>)<br>)<br>)           |                  |                       |                       |                       |                  |                                      |                                      |                              |                              |                                                          |
| CPCF<br>CPCF<br>CPCF                                                | [1]                                          | =                                | 1                                    |                            |                  |                       |                       |                       |                  |                                      |                                      |                              |                              |                                                          |

| 0000                                                                                                                                 |                                                                                                                                                                                                                                                                                                                        | CPU<br>HOF                                                         | "6811.TBL"<br>"INT8"                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                |                           |
|--------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|
|                                                                                                                                      | ;                                                                                                                                                                                                                                                                                                                      |                                                                    |                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                |                           |
|                                                                                                                                      |                                                                                                                                                                                                                                                                                                                        |                                                                    |                                                                                                                                     | ******                                                                                                                                                                                                                                                                                                                                                                                                                                         |                           |
|                                                                                                                                      | ****                                                                                                                                                                                                                                                                                                                   | THE 68HC<br>ARE USED<br>DISPLAY,                                   | 11 IN CONJUN<br>IN DEVELOPED<br>KEYBOARD FUT<br>IAP:EPROM(1)<br>EEPROM(2)<br>RAM<br>I/O<br>LAT<br>RAM<br>I/O & REG<br>BY TIM<br>ANT | CTION WITH THE PSD301<br>MENT OF SOFTWARE FOR<br>NCTION, AND OTHER APPL.<br>C000-FFFF (PROGRAM)<br>B600-BFFF (68HC11)<br>6000-9FFF (DATA)<br>5000-5FFF (PSD301)<br>4000-4007 (PSD301)<br>2000 (LATCH & BUFFER)<br>1000-10FF (68HC11)                                                                                                                                                                                                           | * * * * * * * * * * * * * |
|                                                                                                                                      |                                                                                                                                                                                                                                                                                                                        | ******                                                             |                                                                                                                                     | ****                                                                                                                                                                                                                                                                                                                                                                                                                                           | **                        |
| 6000                                                                                                                                 | ;                                                                                                                                                                                                                                                                                                                      | ORG                                                                | 06000H                                                                                                                              | ;DATA MEMORY                                                                                                                                                                                                                                                                                                                                                                                                                                   |                           |
|                                                                                                                                      | ;*                                                                                                                                                                                                                                                                                                                     | LOOKUP TA                                                          | *********<br>BLES *<br>*******                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                |                           |
| 6000                                                                                                                                 | 3638484331DATTAB                                                                                                                                                                                                                                                                                                       | : DFB                                                              | "68HC11/PSI                                                                                                                         | D311 UP",00H                                                                                                                                                                                                                                                                                                                                                                                                                                   |                           |
| 6023                                                                                                                                 | 54494D4F54CREDIT<br>414E544543<br>524F434B20<br>;                                                                                                                                                                                                                                                                      | S: DFB<br>DFB<br>DFB                                               |                                                                                                                                     | . DUNAVIN"<br>NIXTER MFG."<br>S, ILL. 61071"                                                                                                                                                                                                                                                                                                                                                                                                   |                           |
|                                                                                                                                      | ;****                                                                                                                                                                                                                                                                                                                  | ******                                                             | ******                                                                                                                              | *****                                                                                                                                                                                                                                                                                                                                                                                                                                          |                           |
|                                                                                                                                      | ;                                                                                                                                                                                                                                                                                                                      |                                                                    |                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                |                           |
| C000                                                                                                                                 |                                                                                                                                                                                                                                                                                                                        | ORG                                                                | 0C000H                                                                                                                              | ; PROGRAM MEMORY                                                                                                                                                                                                                                                                                                                                                                                                                               |                           |
| 103D<br>4000<br>2000<br>0001<br>0002<br>0003<br>0004<br>0005<br>0006<br>0007<br>0008<br>0009<br>0008<br>0008<br>0008<br>0008<br>0008 | <ul> <li>PORTBC</li> <li>LAT:</li> <li>KEY1:</li> <li>KEY2:</li> <li>KEY3:</li> <li>KEY3:</li> <li>KEY4:</li> <li>KEY4:</li> <li>KEY5:</li> <li>KEY6:</li> <li>KEY6:</li> <li>KEY7:</li> <li>KEY8:</li> <li>KEY2:</li> <li>KEY2:</li> <li>KEY2:</li> <li>KEY2:</li> <li>KEY2:</li> <li>KEY0:</li> <li>KEY2:</li> </ul> | EQU<br>EQU<br>EQU<br>EQU<br>EQU<br>EQU<br>EQU<br>EQU<br>EQU<br>EQU | 103DH<br>04000H<br>02000H<br>01H<br>02H<br>03H<br>04H<br>05H<br>06H<br>07H<br>08H<br>09H<br>0AH<br>0BH<br>0CH<br>0CH<br>0CH<br>0CH  | <pre>;RAM AND I/O MAPPING REGISTE<br/>;I/O BASE ADDRESS OF THE 301<br/>;LATCH AND BUFFER<br/>;KEYPAD 1<br/>;KEYPAD 2<br/>;KEYPAD 3<br/>;KEYPAD 4<br/>;KEYPAD 4<br/>;KEYPAD 5<br/>;KEYPAD 6<br/>;KEYPAD 6<br/>;KEYPAD 8<br/>;KEYPAD 8<br/>;KEYPAD 7<br/>;KEYPAD 8<br/>;KEYPAD 9<br/>;KEYPAD 4<br/>;KEYPAD 4</pre> |                           |

|             | ;*****                                      | ******            | ******         | *******                                                             |
|-------------|---------------------------------------------|-------------------|----------------|---------------------------------------------------------------------|
|             | ;*                                          |                   | IZATION ROUT   |                                                                     |
|             |                                             |                   |                | *****                                                               |
|             | ;                                           |                   |                |                                                                     |
|             | ;NOTE: C                                    | PTION an          | d TMSK2 must   | be programed in first 64 E                                          |
|             | ; 0                                         | ycles ou          | t of RESET     |                                                                     |
|             | ;                                           |                   |                |                                                                     |
| C000 0F     | START:                                      | SEI               |                | ;SET IRQ MASK                                                       |
| C001 8610   |                                             | LDAA              | #010H          | ;SET RAM AT 1000 AND                                                |
| C003 B7103D |                                             | STAA              | INIT           | ;SET REGISTERS AT 0000                                              |
|             | ;******                                     | *******           | ******         | ******                                                              |
|             | ;                                           |                   |                |                                                                     |
| 0000 =      |                                             |                   |                | R AREA ******                                                       |
| 0000 -      | PORTA:                                      | FÕO               | 0000H          | ;PORT A DATA REGISTER<br>;0001 IS RESERVED                          |
| 0002 =      | PIOC:                                       | FOIL              | 0002H          | ; PARALLEL I/O CONTROL REGISTER                                     |
| 0002 =      | PIOC:                                       | FOU               | 0002H          | ;PARALLEL 1/0 CONTROL REGISTER<br>;PORT C DATA REGISTER (AD0 - AD7) |
| 0004 =      | PORTC:<br>PORTB:<br>PORTCL:                 | FOU               | 0004H          | ; PORT B DATA REGISTER (ABC - ADC)                                  |
| 0005 =      | PORTD.                                      | FOU               | 0005H          | PORT C LATCHED DATA REGISTER                                        |
| 0003 -      | FORICH.                                     | 200               | 00031          | ;0006 IS RESERVED                                                   |
| 0007 =      | DDRC:                                       | EQU               | 0007H          | ;DATA DIRECTION REG FOR PORT C                                      |
| 0008 =      |                                             | EQU               | 0008H          | PORT D DATA REGISTER (RxD, TxD, AND I/O)                            |
| 0009 =      | DDRD:                                       |                   | 0009н          | ;DATA DIRECTION REG FOR PORT D                                      |
| 000A =      |                                             |                   |                | PORT E DATA REGISTER                                                |
| 000B =      | CFORC:                                      | EOU               | 000AH<br>000BH | TIMER COMPARE FORCE REGISTER                                        |
| 000C =      | OC1M:                                       | EOU               | 000CH          | OUTPUT COMPARE 1 MASK REGISTER                                      |
| 000D =      | OC1D:                                       | EOU               | 000DH          | OUTPUT COMPARE 1 DATA REGISTER                                      |
| 000E =      | PORTE:<br>CFORC:<br>OC1M:<br>OC1D:<br>TCNT: | EOU               | 000EH          | TIMER COUNTER REGISTER (16 BIT)                                     |
|             |                                             | ~ ~               |                | ;000F LSB TCNT                                                      |
| 0010 =      | TIC1:                                       | EQU               | 0010H          | TIMER INPUT CAPTURE REGISTER 1 (16 BIT)                             |
|             |                                             |                   |                | ;0011 LSB TIC1                                                      |
| 0012 =      | TIC2:                                       | EQU               | 0012H          | TIMER INPUT CAPTURE REGISTER 2 (16 BIT)                             |
|             |                                             |                   |                | ;0013 LSB TIC2                                                      |
| 0014 =      | TIC3:                                       | EQU               | 0014H          | ;TIMER INPUT CAPTURE REGISTER 3 (16 BIT)                            |
|             |                                             |                   |                | ;0015 LSB TIC3                                                      |
| 0016 =      | TOC1:                                       | EQU               | 0016H          | ;TIMER OUTPUT COMPARE REG 1 (16 BIT)                                |
| 0010 -      |                                             |                   | 00107          | ;0017 LSB TOCI                                                      |
| 0018 =      | TOC2:                                       | EQU               | 0018H          | TIMER OUTPUT COMPARE REG 2 (16 BIT)                                 |
| 001A =      | moo2 .                                      | FOU               | 00137          | ;0019 LSB TOC2<br>;TIMER OUTPUT COMPARE REG 3 (16 BIT)              |
| 001A -      | TOC3:                                       | EQU               | 001AH          | ;001B LSB TOC3                                                      |
| 001C =      | TOC4:                                       | EQU               | 001CH          | TIMER OUTPUT COMPARE REG 4 (16 BIT)                                 |
| 0010        | 1004.                                       | 720               | 00101          | ;001D LSB TOC4                                                      |
| 001E =      | TOC5:                                       | EQU               | 001EH          | ;TIMER OUTPUT COMPARE REG 5 / INPUT CAPTURE                         |
|             |                                             |                   |                | REGISTER 4 (16 BIT) - 001F LSB TOC5/TIC4                            |
| 0020 =      | TCTL1:                                      | EQU               | 0020H          | TIMER CONTROL REGISTER 1                                            |
| 0021 =      |                                             | EQU               | 0021H          | TIMER CONTROL REGISTER 2                                            |
| 0022 =      | TMSK1:                                      |                   | 0022H          | MAIN TIMER INT MASK REGISTER 1                                      |
| 0023 =      |                                             | EQU               |                | MAIN TIMER INT. FLAG REG 1                                          |
| 0024 =      |                                             | EQU               | 0023H<br>0024H | MAIN TIMER INT MASK REGISTER 2                                      |
| 0025 =      | TFLG2:                                      | EQU               | 0025H          | MAIN TIMER INT. FLAG REG 2                                          |
| 0026 =      | PACTL:                                      | EQU               | 0026H          | PULSE ACCUMULATOR CONTROL REG                                       |
| 0027 =      | PACNT:                                      | EQU               | 0027H          | PULSE ACCUMULATOR COUNT REG                                         |
| 0028 =      | SPCR:                                       | EQU               | 0028H<br>0029H | ;SPI CONTROL REGISTER                                               |
| 0029 =      | SPSR:                                       | EQU               |                | ;SPI STATUS REGISTER                                                |
| 002A =      | SPDR:<br>BAUD:                              | EQU               | 002AH          | ;SPI DATA REGISTER                                                  |
| 002B =      |                                             |                   | 002BH          | SCI BAUD RATE CONTROL REGISTER                                      |
| 002C =      | SCCR1:                                      | EQU               | 002CH          | SCI CONTROL REGISTER 1                                              |
| 002D =      | SCCR2:                                      | EQU               | 002DH<br>002EH | ;SCI CONTROL REGISTER 2                                             |
| 002E =      | SCSR:                                       | EQU<br>EQU<br>EQU | 002EH          | SCI STATUS REGISTER                                                 |
| 002F =      | SCDR:                                       | EQU               | 002FH          | ;SCI DATA REGISTER                                                  |
|             |                                             |                   |                |                                                                     |

| 0030 =                                                                                                                                                                                                                                                                                      | ADCTL:                                               | EQU                                                                                                                                                                                                          | 0030H                                                                                                                                                                                                              | ;A/D CONTROL/STATUS REGISTER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0031 =                                                                                                                                                                                                                                                                                      | ADR1:                                                | EQU                                                                                                                                                                                                          | 0031H                                                                                                                                                                                                              | ;A/D RESULT REGISTER 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 0032 =                                                                                                                                                                                                                                                                                      | ADR2:                                                | EQU                                                                                                                                                                                                          | 0032H                                                                                                                                                                                                              | A/D RESULT REGISTER 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0033 =                                                                                                                                                                                                                                                                                      | ADR3:                                                |                                                                                                                                                                                                              | 0033H                                                                                                                                                                                                              | ;A/D RESULT REGISTER 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                                                                                                                                                                                                                                                             |                                                      | EQU                                                                                                                                                                                                          |                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0034 =                                                                                                                                                                                                                                                                                      | ADR4:                                                | EQU                                                                                                                                                                                                          | 0034H                                                                                                                                                                                                              | ;A/D RESULT REGISTER 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                                                                                                                                                                                                                                                             |                                                      |                                                                                                                                                                                                              |                                                                                                                                                                                                                    | ;0035 - 0038 RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0039 =                                                                                                                                                                                                                                                                                      | OPTION:                                              | EOU                                                                                                                                                                                                          | 0039H                                                                                                                                                                                                              | SYSTEM CONFIGURATION OPTIONS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 003A =                                                                                                                                                                                                                                                                                      | COPRST:                                              | -                                                                                                                                                                                                            | 003AH                                                                                                                                                                                                              | ARM/RESET COP TIMER CIRCUITRY                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                                                                                                                                                                                                                                                                                             |                                                      | -                                                                                                                                                                                                            |                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 003B =                                                                                                                                                                                                                                                                                      | PPROG:                                               | EQU                                                                                                                                                                                                          | 003BH                                                                                                                                                                                                              | ;EEPROM PROGRAMMING REGISTER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 003C =                                                                                                                                                                                                                                                                                      | HPRIO:                                               | EQU                                                                                                                                                                                                          | 003CH                                                                                                                                                                                                              | ;HIGHEST PRIORITY INTERRUPT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                                                                                                                                                                                                                                                                             | ; INIT:                                              | EQU                                                                                                                                                                                                          | 003DH                                                                                                                                                                                                              | ;RAM AND I/O MAPPING REGISTER (NEW ADD.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 003E =                                                                                                                                                                                                                                                                                      | TEST1:                                               | EQU                                                                                                                                                                                                          | 003EH                                                                                                                                                                                                              | FACTORY TEST REGISTER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 003F =                                                                                                                                                                                                                                                                                      | CONFIG:                                              |                                                                                                                                                                                                              | 003FH                                                                                                                                                                                                              | CONFIGURATION CONTROL REGISTER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0001                                                                                                                                                                                                                                                                                        |                                                      | 770                                                                                                                                                                                                          | VUJFI                                                                                                                                                                                                              | CONFIGURATION CONTROL REGISTER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                                                                                                                                                                                                                                                                             | · · · · · · · ·                                      |                                                                                                                                                                                                              |                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                                                                                                                                                                                                                                                                             | •                                                    |                                                                                                                                                                                                              |                                                                                                                                                                                                                    | NAL RAM ******                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 1000 =                                                                                                                                                                                                                                                                                      | FLAGS:                                               | EQU                                                                                                                                                                                                          | 1000н                                                                                                                                                                                                              | ;FLAG REGISTER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 1001 =                                                                                                                                                                                                                                                                                      | LA1:                                                 | EQU                                                                                                                                                                                                          | 1001H                                                                                                                                                                                                              | LATCH DATA REGISTER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 1002 =                                                                                                                                                                                                                                                                                      | STOR:                                                | EQU                                                                                                                                                                                                          | 1002H                                                                                                                                                                                                              | BASIC RAM STORAGE AREA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                                                                                                                                                                                                                                                             |                                                      |                                                                                                                                                                                                              |                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 10FF =                                                                                                                                                                                                                                                                                      | STACK:                                               | EQU                                                                                                                                                                                                          | lOFFH                                                                                                                                                                                                              | ;STACK AREA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                                                                                                                                                                                                                                                                             | ;                                                    |                                                                                                                                                                                                              |                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                                                                                                                                                                                                                                                                             | ******                                               | 2K X 8                                                                                                                                                                                                       | EXTERNAL RAI                                                                                                                                                                                                       | ví *****                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 5000 =                                                                                                                                                                                                                                                                                      | MASSTOR:                                             |                                                                                                                                                                                                              | 05000H                                                                                                                                                                                                             | ;MASS STORAGE RAM IN PSD301                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 5000                                                                                                                                                                                                                                                                                        |                                                      | 120                                                                                                                                                                                                          | 000001                                                                                                                                                                                                             | MADD DIORAGE RAM IN PODDOI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                                                                                                                                                                                                                                                                             | <i>i</i>                                             |                                                                                                                                                                                                              |                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                                                                                                                                                                                                                                                                             |                                                      |                                                                                                                                                                                                              | REA, 512 BY                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| B600 =                                                                                                                                                                                                                                                                                      | EROM:                                                | EQU                                                                                                                                                                                                          | <b>0B6</b> 00H                                                                                                                                                                                                     | ;DATA RETENTION AREA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                                                                                                                                                                                                                                                                             | ;                                                    |                                                                                                                                                                                                              |                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                                                                                                                                                                                                                                                                             | ******                                               | ******                                                                                                                                                                                                       | ******                                                                                                                                                                                                             | ***********                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| C006 01                                                                                                                                                                                                                                                                                     | '                                                    | NOP                                                                                                                                                                                                          |                                                                                                                                                                                                                    | SLIGHT DELAY TO ALLOW REGISTER SET UP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                                                                                                                                                                                                                                                                             |                                                      |                                                                                                                                                                                                              |                                                                                                                                                                                                                    | SDIGHT DELAT TO ALLOW REGISTER SET OF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                                                                                                                                                                                                                                                                             |                                                      | * * * * *                                                                                                                                                                                                    | #0                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| C007 86E3                                                                                                                                                                                                                                                                                   |                                                      | LDAA                                                                                                                                                                                                         | #0E3H                                                                                                                                                                                                              | ;SET UP OPTION REG ADPU =1, CSEL = 1,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                                                                                                                                                                                                                                                                             |                                                      | LDAA                                                                                                                                                                                                         | #0E3H                                                                                                                                                                                                              | ;SET UP OPTION REG ADPU =1, CSEL = 1,<br>IRQE = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| C007 86E3<br>C009 9739                                                                                                                                                                                                                                                                      |                                                      | ldaa<br>Staa                                                                                                                                                                                                 |                                                                                                                                                                                                                    | IRQE = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                             |                                                      |                                                                                                                                                                                                              |                                                                                                                                                                                                                    | IRQE = 1<br>;(ENABLE EEPROM CHARGE PUMP, IRQ EDGE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| C009 9739                                                                                                                                                                                                                                                                                   |                                                      | STAA                                                                                                                                                                                                         | OPTION                                                                                                                                                                                                             | <pre>IRQE = 1 ;(ENABLE EEPROM CHARGE PUMP, IRQ EDGE SENSITIVE)</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| C009 9739<br>C00B 8602                                                                                                                                                                                                                                                                      |                                                      | STAA<br>LDAA                                                                                                                                                                                                 | OPTION<br>#002H                                                                                                                                                                                                    | IRQE = 1<br>;(ENABLE EEPROM CHARGE PUMP, IRQ EDGE<br>SENSITIVE)<br>;SET TIMER PRESCALER TO 8                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| C009 9739<br>C00B 8602<br>C00D 9724                                                                                                                                                                                                                                                         |                                                      | STAA<br>LDAA<br>STAA                                                                                                                                                                                         | OPTION<br>#002H<br>TMSK2                                                                                                                                                                                           | IRQE = 1<br>;(ENABLE EEPROM CHARGE PUMP, IRQ EDGE<br>SENSITIVE)<br>;SET TIMER PRESCALER TO 8<br>;AND DISABLE TIMER INTERRUPTS                                                                                                                                                                                                                                                                                                                                                                                                                         |
| C009 9739<br>C00B 8602<br>C00D 9724<br>C00F 7F0028                                                                                                                                                                                                                                          |                                                      | STAA<br>LDAA                                                                                                                                                                                                 | OPTION<br>#002H                                                                                                                                                                                                    | IRQE = 1<br>;(ENABLE EEPROM CHARGE PUMP, IRQ EDGE<br>SENSITIVE)<br>;SET TIMER PRESCALER TO 8                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| C009 9739<br>C00B 8602<br>C00D 9724                                                                                                                                                                                                                                                         |                                                      | STAA<br>LDAA<br>STAA                                                                                                                                                                                         | OPTION<br>#002H<br>TMSK2                                                                                                                                                                                           | IRQE = 1<br>;(ENABLE EEPROM CHARGE PUMP, IRQ EDGE<br>SENSITIVE)<br>;SET TIMER PRESCALER TO 8<br>;AND DISABLE TIMER INTERRUPTS<br>;DISABLE ALL SPI INT.                                                                                                                                                                                                                                                                                                                                                                                                |
| C009 9739<br>C00B 8602<br>C00D 9724<br>C00F 7F0028<br>C012 8E10FF                                                                                                                                                                                                                           |                                                      | STAA<br>LDAA<br>STAA<br>CLR<br>LDS                                                                                                                                                                           | OPTION<br>#002H<br>TMSK2<br>SPCR<br>#STACK                                                                                                                                                                         | IRQE = 1<br>;(ENABLE EEPROM CHARGE PUMP, IRQ EDGE<br>SENSITIVE)<br>;SET TIMER PRESCALER TO 8<br>;AND DISABLE TIMER INTERRUPTS                                                                                                                                                                                                                                                                                                                                                                                                                         |
| C009 9739<br>C00B 8602<br>C00D 9724<br>C00F 7F0028<br>C012 8E10FF<br>C015 8680                                                                                                                                                                                                              |                                                      | STAA<br>LDAA<br>STAA<br>CLR<br>LDS<br>LDAA                                                                                                                                                                   | OPTION<br>#002H<br>TMSK2<br>SPCR<br>#STACK<br>#080H                                                                                                                                                                | IRQE = 1<br>;(ENABLE EEPROM CHARGE PUMP, IRQ EDGE<br>SENSITIVE)<br>;SET TIMER PRESCALER TO 8<br>;AND DISABLE TIMER INTERRUPTS<br>;DISABLE ALL SPI INT.<br>;SET UP STACK                                                                                                                                                                                                                                                                                                                                                                               |
| C009 9739<br>C00B 8602<br>C00D 9724<br>C00F 7F0028<br>C012 8E10FF                                                                                                                                                                                                                           |                                                      | STAA<br>LDAA<br>STAA<br>CLR<br>LDS<br>LDAA<br>STAA                                                                                                                                                           | OPTION<br>#002H<br>TMSK2<br>SPCR<br>#STACK<br>#080H<br>PACTL                                                                                                                                                       | <pre>IRQE = 1 ;(ENABLE EEPROM CHARGE PUMP, IRQ EDGE SENSITIVE) ;SET TIMER PRESCALER TO 8 ;AND DISABLE TIMER INTERRUPTS ;DISABLE ALL SPI INT. ;SET UP STACK ;PA7 OUTPUT</pre>                                                                                                                                                                                                                                                                                                                                                                          |
| C009 9739<br>C00B 8602<br>C00D 9724<br>C00F 7F0028<br>C012 8E10FF<br>C015 8680<br>C017 9726                                                                                                                                                                                                 | ; * * * * * * *                                      | STAA<br>STAA<br>CLR<br>LDS<br>LDAA<br>STAA<br>INITIAL                                                                                                                                                        | OPTION<br>#002H<br>TMSK2<br>SPCR<br>#STACK<br>#080H<br>PACTL<br>IZE THE SCI                                                                                                                                        | <pre>IRQE = 1 ;(ENABLE EEPROM CHARGE PUMP, IRQ EDGE SENSITIVE) ;SET TIMER PRESCALER TO 8 ;AND DISABLE TIMER INTERRUPTS ;DISABLE ALL SPI INT. ;SET UP STACK ;PA7 OUTPUT TO 9600 BAUD AT 8MHZ (DISABLED)</pre>                                                                                                                                                                                                                                                                                                                                          |
| C009 9739<br>C00B 8602<br>C00D 9724<br>C00F 7F0028<br>C012 8E10FF<br>C015 8680                                                                                                                                                                                                              |                                                      | STAA<br>LDAA<br>STAA<br>CLR<br>LDS<br>LDAA<br>STAA                                                                                                                                                           | OPTION<br>#002H<br>TMSK2<br>SPCR<br>#STACK<br>#080H<br>PACTL<br>IZE THE SCI                                                                                                                                        | <pre>IRQE = 1 ;(ENABLE EEPROM CHARGE PUMP, IRQ EDGE SENSITIVE) ;SET TIMER PRESCALER TO 8 ;AND DISABLE TIMER INTERRUPTS ;DISABLE ALL SPI INT. ;SET UP STACK ;PA7 OUTPUT TO 9600 BAUD AT 8MHZ (DISABLED) ;INIT. PORT D DDR (02H)</pre>                                                                                                                                                                                                                                                                                                                  |
| C009 9739<br>C00B 8602<br>C00D 9724<br>C00F 7F0028<br>C012 8E10FF<br>C015 8680<br>C017 9726                                                                                                                                                                                                 | ; * * * * * * *                                      | STAA<br>STAA<br>CLR<br>LDS<br>LDAA<br>STAA<br>INITIAL                                                                                                                                                        | OPTION<br>#002H<br>TMSK2<br>SPCR<br>#STACK<br>#080H<br>PACTL<br>IZE THE SCI                                                                                                                                        | <pre>IRQE = 1 ;(ENABLE EEPROM CHARGE PUMP, IRQ EDGE SENSITIVE) ;SET TIMER PRESCALER TO 8 ;AND DISABLE TIMER INTERRUPTS ;DISABLE ALL SPI INT. ;SET UP STACK ;PA7 OUTPUT TO 9600 BAUD AT 8MHZ (DISABLED) ;INIT. PORT D DDR (02H)</pre>                                                                                                                                                                                                                                                                                                                  |
| C009 9739<br>C00B 8602<br>C00D 9724<br>C00F 7F0028<br>C012 8E10FF<br>C015 8680<br>C017 9726<br>C019 86FC<br>C01B 9709                                                                                                                                                                       | ; * * * * * * *                                      | STAA<br>LDAA<br>STAA<br>CLR<br>LDS<br>LDAA<br>STAA<br>INITIAL<br>LDAA<br>STAA                                                                                                                                | OPTION<br>#002H<br>TMSK2<br>SPCR<br>#STACK<br>#080H<br>PACTL<br>IZE THE SCI<br>#0FCH<br>DDRD                                                                                                                       | <pre>IRQE = 1 ;(ENABLE EEPROM CHARGE PUMP, IRQ EDGE SENSITIVE) ;SET TIMER PRESCALER TO 8 ;AND DISABLE TIMER INTERRUPTS ;DISABLE ALL SPI INT. ;SET UP STACK ;PA7 OUTPUT TO 9600 BAUD AT 8MHZ (DISABLED) ;INIT. PORT D DDR (02H) ;PD0, PD1 - INPUT, PD2-PD5 - OUTPUT</pre>                                                                                                                                                                                                                                                                              |
| C009 9739<br>C00B 8602<br>C00D 9724<br>C00F 7F0028<br>C012 8E10FF<br>C015 8680<br>C017 9726<br>C019 86FC<br>C01B 9709<br>C01D 8600                                                                                                                                                          | ; * * * * * * *                                      | STAA<br>LDAA<br>STAA<br>CLR<br>LDS<br>LDAA<br>STAA<br>INITIAL<br>LDAA<br>STAA<br>LDAA                                                                                                                        | OPTION<br>#002H<br>TMSK2<br>SPCR<br>#STACK<br>#080H<br>PACTL<br>IZE THE SCI<br>#0FCH<br>DDRD<br>#000H                                                                                                              | <pre>IRQE = 1 ;(ENABLE EEPROM CHARGE PUMP, IRQ EDGE SENSITIVE) ;SET TIMER PRESCALER TO 8 ;AND DISABLE TIMER INTERRUPTS ;DISABLE ALL SPI INT. ;SET UP STACK ;PA7 OUTPUT TO 9600 BAUD AT 8MHZ (DISABLED) ;INIT. PORT D DDR (02H)</pre>                                                                                                                                                                                                                                                                                                                  |
| C009 9739<br>C00B 8602<br>C00D 9724<br>C00F 7F0028<br>C012 8E10FF<br>C015 8680<br>C017 9726<br>C019 86FC<br>C01B 9709<br>C01D 8600<br>C01F 9708                                                                                                                                             | ; * * * * * * *                                      | STAA<br>LDAA<br>STAA<br>CLR<br>LDS<br>LDAA<br>STAA<br>INITIAL<br>LDAA<br>STAA<br>LDAA<br>STAA                                                                                                                | OPTION<br>#002H<br>TMSK2<br>SPCR<br>#STACK<br>#080H<br>PACTL<br>IZE THE SCI<br>#0FCH<br>DDRD<br>#000H<br>PORTD                                                                                                     | <pre>IRQE = 1 ;(ENABLE EEPROM CHARGE PUMP, IRQ EDGE SENSITIVE) ;SET TIMER PRESCALER TO 8 ;AND DISABLE TIMER INTERRUPTS ;DISABLE ALL SPI INT. ;SET UP STACK ;PA7 OUTPUT TO 9600 BAUD AT 8MHZ (DISABLED) ;INIT. PORT D DDR (02H) ;PD0, PD1 - INPUT, PD2-PD5 - OUTPUT ;SET UP PORT D</pre>                                                                                                                                                                                                                                                               |
| C009 9739<br>C00B 8602<br>C00D 9724<br>C00F 7F0028<br>C012 8E10FF<br>C015 8680<br>C017 9726<br>C019 86FC<br>C01B 9709<br>C01D 8600<br>C01F 9708<br>C021 7F002C                                                                                                                              | ; * * * * * * *                                      | STAA<br>LDAA<br>STAA<br>CLR<br>LDS<br>LDAA<br>STAA<br>INITIAL<br>LDAA<br>STAA<br>LDAA<br>STAA<br>CLR                                                                                                         | OPTION<br>#002H<br>TMSK2<br>SPCR<br>#STACK<br>#080H<br>PACTL<br>IZE THE SCI<br>#0FCH<br>DDRD<br>#000H<br>PORTD<br>SCCR1                                                                                            | <pre>IRQE = 1 ;(ENABLE EEPROM CHARGE PUMP, IRQ EDGE SENSITIVE) ;SET TIMER PRESCALER TO 8 ;AND DISABLE TIMER INTERRUPTS ;DISABLE ALL SPI INT. ;SET UP STACK ;PA7 OUTPUT TO 9600 BAUD AT 8MHZ (DISABLED) ;INIT. PORT D DDR (02H) ;PD0, PD1 - INPUT, PD2-PD5 - OUTPUT</pre>                                                                                                                                                                                                                                                                              |
| C009 9739<br>C00B 8602<br>C00D 9724<br>C00F 7F0028<br>C012 8E10FF<br>C015 8680<br>C017 9726<br>C019 86FC<br>C01B 9709<br>C01D 8600<br>C01F 9708<br>C021 7F002C<br>C024 7F002D                                                                                                               | ; * * * * * * *                                      | STAA<br>LDAA<br>STAA<br>CLR<br>LDS<br>LDAA<br>STAA<br>INITIAL<br>LDAA<br>STAA<br>LDAA<br>STAA                                                                                                                | OPTION<br>#002H<br>TMSK2<br>SPCR<br>#STACK<br>#080H<br>PACTL<br>IZE THE SCI<br>#0FCH<br>DDRD<br>#000H<br>PORTD                                                                                                     | <pre>IRQE = 1 ;(ENABLE EEPROM CHARGE PUMP, IRQ EDGE SENSITIVE) ;SET TIMER PRESCALER TO 8 ;AND DISABLE TIMER INTERRUPTS ;DISABLE ALL SPI INT. ;SET UP STACK ;PA7 OUTPUT TO 9600 BAUD AT 8MHZ (DISABLED) ;INIT. PORT D DDR (02H) ;PD0, PD1 - INPUT, PD2-PD5 - OUTPUT ;SET UP PORT D</pre>                                                                                                                                                                                                                                                               |
| C009 9739<br>C00B 8602<br>C00D 9724<br>C00F 7F0028<br>C012 8E10FF<br>C015 8680<br>C017 9726<br>C019 86FC<br>C01B 9709<br>C01D 8600<br>C01F 9708<br>C021 7F002C                                                                                                                              | ; * * * * * * *                                      | STAA<br>LDAA<br>STAA<br>CLR<br>LDS<br>LDAA<br>STAA<br>INITIAL<br>LDAA<br>STAA<br>LDAA<br>STAA<br>CLR                                                                                                         | OPTION<br>#002H<br>TMSK2<br>SPCR<br>#STACK<br>#080H<br>PACTL<br>IZE THE SCI<br>#0FCH<br>DDRD<br>#000H<br>PORTD<br>SCCR1                                                                                            | <pre>IRQE = 1 ;(ENABLE EEPROM CHARGE PUMP, IRQ EDGE SENSITIVE) ;SET TIMER PRESCALER TO 8 ;AND DISABLE TIMER INTERRUPTS ;DISABLE ALL SPI INT. ;SET UP STACK ;PA7 OUTPUT TO 9600 BAUD AT 8MHZ (DISABLED) ;INIT. PORT D DDR (02H) ;PD0, PD1 - INPUT, PD2-PD5 - OUTPUT ;SET UP PORT D</pre>                                                                                                                                                                                                                                                               |
| C009 9739<br>C00B 8602<br>C00D 9724<br>C00F 7F0028<br>C012 8E10FF<br>C015 8680<br>C017 9726<br>C019 86FC<br>C01B 9709<br>C01D 8600<br>C01F 9708<br>C021 7F002C<br>C024 7F002D<br>C027 962E                                                                                                  | ; * * * * * * *                                      | STAA<br>LDAA<br>STAA<br>CLR<br>LDS<br>LDAA<br>STAA<br>INITIAL<br>LDAA<br>STAA<br>LDAA<br>STAA<br>CLR<br>CLR<br>LDAA                                                                                          | OPTION<br>#002H<br>TMSK2<br>SPCR<br>#STACK<br>#080H<br>PACTL<br>IZE THE SCI<br>#0FCH<br>DDRD<br>#000H<br>PORTD<br>SCCR1<br>SCCR2                                                                                   | <pre>IRQE = 1 ;(ENABLE EEPROM CHARGE PUMP, IRQ EDGE SENSITIVE) ;SET TIMER PRESCALER TO 8 ;AND DISABLE TIMER INTERRUPTS ;DISABLE ALL SPI INT. ;SET UP STACK ;PA7 OUTPUT TO 9600 BAUD AT 8MHZ (DISABLED) ;INIT. PORT D DDR (02H) ;PD0, PD1 - INPUT, PD2-PD5 - OUTPUT ;SET UP SER. COM. CON. REG. 1 ;TO CLEAR TDRE AND TC OF SCSR</pre>                                                                                                                                                                                                                  |
| C009 9739<br>C00B 8602<br>C00D 9724<br>C00F 7F0028<br>C012 8E10FF<br>C015 8680<br>C017 9726<br>C019 86FC<br>C01B 9709<br>C01D 8600<br>C01F 9708<br>C021 7F002C<br>C024 7F002D<br>C027 962E<br>C029 4F                                                                                       | ; * * * * * * *                                      | STAA<br>LDAA<br>STAA<br>CLR<br>LDS<br>LDAA<br>STAA<br>INITIAL<br>LDAA<br>STAA<br>LDAA<br>STAA<br>CLR<br>CLR<br>LDAA<br>CLR                                                                                   | OPTION<br>#002H<br>TMSK2<br>SPCR<br>#STACK<br>#080H<br>PACTL<br>IZE THE SCI<br>#0FCH<br>DDRD<br>#000H<br>PORTD<br>SCCR1<br>SCCR2<br>SCSR                                                                           | <pre>IRQE = 1 ;(ENABLE EEPROM CHARGE PUMP, IRQ EDGE SENSITIVE) ;SET TIMER PRESCALER TO 8 ;AND DISABLE TIMER INTERRUPTS ;DISABLE ALL SPI INT. ;SET UP STACK ;PA7 OUTPUT TO 9600 BAUD AT 8MHZ (DISABLED) ;INIT. PORT D DDR (02H) ;PD0, PD1 - INPUT, PD2-PD5 - OUTPUT ;SET UP PORT D ;SET UP SER. COM. CON. REG. 1</pre>                                                                                                                                                                                                                                 |
| C009 9739<br>C00B 8602<br>C00D 9724<br>C00F 7F0028<br>C012 8E10FF<br>C015 8680<br>C017 9726<br>C019 86FC<br>C01B 9709<br>C01D 8600<br>C01F 9708<br>C021 7F002C<br>C024 7F002D<br>C027 962E                                                                                                  | ;*******<br>ONSCI:                                   | STAA<br>LDAA<br>STAA<br>CLR<br>LDS<br>LDAA<br>STAA<br>INITIAL<br>LDAA<br>STAA<br>LDAA<br>CLR<br>CLR<br>LDAA<br>CLRA<br>STAA                                                                                  | OPTION<br>#002H<br>TMSK2<br>SPCR<br>#STACK<br>#080H<br>PACTL<br>IZE THE SCI<br>#0FCH<br>DDRD<br>#000H<br>PORTD<br>SCCR1<br>SCCR2<br>SCSR<br>SCDR                                                                   | <pre>IRQE = 1 ;(ENABLE EEPROM CHARGE PUMP, IRQ EDGE SENSITIVE) ;SET TIMER PRESCALER TO 8 ;AND DISABLE TIMER INTERRUPTS ;DISABLE ALL SPI INT. ;SET UP STACK ;PA7 OUTPUT TO 9600 BAUD AT 8MHZ (DISABLED) ;INIT. PORT D DDR (02H) ;PD0, PD1 - INPUT, PD2-PD5 - OUTPUT ;SET UP PORT D ;SET UP SER. COM. CON. REG. 1 ;TO CLEAR TDRE AND TC OF SCSR ;READ STATUS REG., LOAD TRANS. DATA REG.</pre>                                                                                                                                                          |
| C009 9739<br>C00B 8602<br>C00D 9724<br>C00F 7F0028<br>C012 8E10FF<br>C015 8680<br>C017 9726<br>C019 86FC<br>C01B 9709<br>C01D 8600<br>C01F 9708<br>C021 7F002D<br>C027 962E<br>C029 4F<br>C02A 972F                                                                                         | ;*******<br>ONSCI:<br>;******                        | STAA<br>LDAA<br>STAA<br>CLR<br>LDS<br>LDAA<br>STAA<br>INITIAL<br>LDAA<br>STAA<br>CLR<br>CLR<br>LDAA<br>CLRA<br>STAA<br>INITIAL                                                                               | OPTION<br>#002H<br>TMSK2<br>SPCR<br>#STACK<br>#080H<br>PACTL<br>IZE THE SCI<br>#0FCH<br>DDRD<br>#000H<br>PORTD<br>SCCR1<br>SCCR2<br>SCSR<br>SCDR<br>IZE THE 301                                                    | <pre>IRQE = 1 ;(ENABLE EEPROM CHARGE PUMP, IRQ EDGE SENSITIVE) ;SET TIMER PRESCALER TO 8 ;AND DISABLE TIMER INTERRUPTS ;DISABLE ALL SPI INT. ;SET UP STACK ;PA7 OUTPUT TO 9600 BAUD AT 8MHZ (DISABLED) ;INIT. PORT D DDR (02H) ;PD0, PD1 - INPUT, PD2-PD5 - OUTPUT ;SET UP PORT D ;SET UP SER. COM. CON. REG. 1 ;TO CLEAR TDRE AND TC OF SCSR ;READ STATUS REG., LOAD TRANS. DATA REG. FOR DISPLAY INTERFACE</pre>                                                                                                                                    |
| C009 9739<br>C00B 8602<br>C00D 9724<br>C00F 7F0028<br>C012 8E10FF<br>C015 8680<br>C017 9726<br>C019 86FC<br>C01B 9709<br>C01D 8600<br>C01F 9708<br>C021 7F002C<br>C024 7F002D<br>C027 962E<br>C029 4F<br>C02A 972F<br>C02C CEFFFF                                                           | ;*******<br>ONSCI:                                   | STAA<br>LDAA<br>STAA<br>CLR<br>LDS<br>LDAA<br>STAA<br>INITIAL<br>LDAA<br>STAA<br>CLR<br>CLR<br>CLR<br>CLR<br>STAA<br>INITIAL<br>LDX                                                                          | OPTION<br>#002H<br>TMSK2<br>SPCR<br>#STACK<br>#080H<br>PACTL<br>IZE THE SCI<br>#0FCH<br>DDRD<br>#000H<br>PORTD<br>SCCR1<br>SCCR1<br>SCCR2<br>SCSR<br>SCDR<br>IZE THE 301<br>#0FFFFH                                | <pre>IRQE = 1 ;(ENABLE EEPROM CHARGE PUMP, IRQ EDGE SENSITIVE) ;SET TIMER PRESCALER TO 8 ;AND DISABLE TIMER INTERRUPTS ;DISABLE ALL SPI INT. ;SET UP STACK ;PA7 OUTPUT TO 9600 BAUD AT 8MHZ (DISABLED) ;INIT. PORT D DDR (02H) ;PD0, PD1 - INPUT, PD2-PD5 - OUTPUT ;SET UP PORT D ;SET UP SER. COM. CON. REG. 1 ;TO CLEAR TDRE AND TC OF SCSR ;READ STATUS REG., LOAD TRANS. DATA REG.</pre>                                                                                                                                                          |
| C009 9739<br>C00B 8602<br>C00D 9724<br>C00F 7F0028<br>C012 8E10FF<br>C015 8680<br>C017 9726<br>C019 86FC<br>C01B 9709<br>C01D 8600<br>C01F 9708<br>C021 7F002D<br>C027 962E<br>C029 4F<br>C02A 972F                                                                                         | ;*******<br>ONSCI:<br>;******                        | STAA<br>LDAA<br>STAA<br>CLR<br>LDS<br>LDAA<br>STAA<br>INITIAL<br>LDAA<br>STAA<br>CLR<br>CLR<br>LDAA<br>CLRA<br>STAA<br>INITIAL                                                                               | OPTION<br>#002H<br>TMSK2<br>SPCR<br>#STACK<br>#080H<br>PACTL<br>IZE THE SCI<br>#0FCH<br>DDRD<br>#000H<br>PORTD<br>SCCR1<br>SCCR2<br>SCSR<br>SCDR<br>IZE THE 301                                                    | <pre>IRQE = 1 ;(ENABLE EEPROM CHARGE PUMP, IRQ EDGE SENSITIVE) ;SET TIMER PRESCALER TO 8 ;AND DISABLE TIMER INTERRUPTS ;DISABLE ALL SPI INT. ;SET UP STACK ;PA7 OUTPUT TO 9600 BAUD AT 8MHZ (DISABLED) ;INIT. PORT D DDR (02H) ;PD0, PD1 - INPUT, PD2-PD5 - OUTPUT ;SET UP PORT D ;SET UP SER. COM. CON. REG. 1 ;TO CLEAR TDRE AND TC OF SCSR ;READ STATUS REG., LOAD TRANS. DATA REG. FOR DISPLAY INTERFACE</pre>                                                                                                                                    |
| C009 9739<br>C00B 8602<br>C00D 9724<br>C00F 7F0028<br>C012 8E10FF<br>C015 8680<br>C017 9726<br>C019 86FC<br>C01B 9709<br>C01D 8600<br>C01F 9708<br>C021 7F002C<br>C024 7F002D<br>C027 962E<br>C029 4F<br>C02A 972F<br>C02C CEFFFF                                                           | ;*******<br>ONSCI:<br>;*******<br>ONPIA:             | STAA<br>LDAA<br>STAA<br>CLR<br>LDS<br>LDAA<br>STAA<br>INITIAL<br>LDAA<br>STAA<br>CLR<br>CLR<br>CLR<br>CLR<br>CLR<br>STAA<br>INITIAL<br>LDX<br>STX                                                            | OPTION<br>#002H<br>TMSK2<br>SPCR<br>#STACK<br>#080H<br>PACTL<br>IZE THE SCI<br>#0FCH<br>DDRD<br>#000H<br>PORTD<br>SCCR1<br>SCCR2<br>SCCR<br>IZE THE 301<br>#0FFFFH<br>PORTBC+4                                     | <pre>IRQE = 1 ;(ENABLE EEPROM CHARGE PUMP, IRQ EDGE SENSITIVE) ;SET TIMER PRESCALER TO 8 ;AND DISABLE TIMER INTERRUPTS ;DISABLE ALL SPI INT. ;SET UP STACK ;PA7 OUTPUT TO 9600 BAUD AT 8MHZ (DISABLED) ;INIT. PORT D DDR (02H) ;PD0, PD1 - INPUT, PD2-PD5 - OUTPUT ;SET UP PORT D ;SET UP SER. COM. CON. REG. 1 ;TO CLEAR TDRE AND TC OF SCSR ;READ STATUS REG., LOAD TRANS. DATA REG. FOR DISPLAY INTERFACE ;SET UP PORTS B &amp; C AS OUTPUTS</pre>                                                                                                 |
| C009 9739<br>C00B 8602<br>C00D 9724<br>C00F 7F0028<br>C012 8E10FF<br>C015 8680<br>C017 9726<br>C019 86FC<br>C019 86FC<br>C019 8600<br>C01F 9708<br>C021 7F002C<br>C024 7F002D<br>C027 962E<br>C029 4F<br>C02A 972F<br>C02C CEFFFF<br>C02C CEFFFF                                            | ;*******<br>ONSCI:<br>;*******<br>ONPIA:<br>;******* | STAA<br>LDAA<br>STAA<br>CLR<br>LDS<br>LDAA<br>STAA<br>INITIAL<br>LDAA<br>STAA<br>CLR<br>CLR<br>LDAA<br>CLRA<br>STAA<br>INITIAL<br>LDX<br>STX<br>DISPLAY                                                      | OPTION<br>#002H<br>TMSK2<br>SPCR<br>#STACK<br>#080H<br>PACTL<br>IZE THE SCI<br>#0FCH<br>DDRD<br>#000H<br>FORTD<br>SCCR1<br>SCCR2<br>SCSR<br>SCDR<br>IZE THE 301<br>#0FFFFH<br>PORTBC+4<br>SET UP (NEW              | <pre>IRQE = 1 ;(ENABLE EEPROM CHARGE PUMP, IRQ EDGE SENSITIVE) ;SET TIMER PRESCALER TO 8 ;AND DISABLE TIMER INTERRUPTS ;DISABLE ALL SPI INT. ;SET UP STACK ;PA7 OUTPUT TO 9600 BAUD AT 8MHZ (DISABLED) ;INIT. PORT D DDR (02H) ;PD0, PD1 - INPUT, PD2-PD5 - OUTPUT ;SET UP PORT D ;SET UP SER. COM. CON. REG. 1 ;TO CLEAR TDRE AND TC OF SCSR ;READ STATUS REG., LOAD TRANS. DATA REG. FOR DISPLAY INTERFACE ;SET UP PORTS B &amp; C AS OUTPUTS V REV. 15 MAY 91) ******</pre>                                                                        |
| C009 9739<br>C00B 8602<br>C00D 9724<br>C00F 7F0028<br>C012 8E10FF<br>C015 8680<br>C017 9726<br>C019 86FC<br>C01B 9709<br>C01D 8600<br>C01F 9708<br>C021 7F002D<br>C027 962E<br>C029 4F<br>C022 CEFFFF<br>C02F FF4004<br>C032 CE2710                                                         | ;*******<br>ONSCI:<br>;*******<br>ONPIA:             | STAA<br>LDAA<br>STAA<br>CLR<br>LDS<br>LDAA<br>STAA<br>INITIAL<br>LDAA<br>STAA<br>CLR<br>CLR<br>CLR<br>CLR<br>CLR<br>STAA<br>INITIAL<br>LDX<br>STX<br>DISPLAY<br>LDX                                          | OPTION<br>#002H<br>TMSK2<br>SPCR<br>#STACK<br>#080H<br>PACTL<br>IZE THE SCI<br>#0FCH<br>DDRD<br>#000H<br>PORTD<br>SCCR1<br>SCCR2<br>SCSR<br>SCDR<br>IZE THE 301<br>#0FFFFH<br>PORTBC+4<br>SET UP (NEW<br>#02710H   | <pre>IRQE = 1 ;(ENABLE EEPROM CHARGE PUMP, IRQ EDGE SENSITIVE) ;SET TIMER PRESCALER TO 8 ;AND DISABLE TIMER INTERRUPTS ;DISABLE ALL SPI INT. ;SET UP STACK ;PA7 OUTPUT TO 9600 BAUD AT 8MHZ (DISABLED) ;INIT. PORT D DDR (02H) ;PD0, PD1 - INPUT, PD2-PD5 - OUTPUT ;SET UP PORT D ;SET UP SER. COM. CON. REG. 1 ;TO CLEAR TDRE AND TC OF SCSR ;READ STATUS REG., LOAD TRANS. DATA REG. FOR DISPLAY INTERFACE ;SET UP PORTS B &amp; C AS OUTPUTS N REV. 15 MAY 91) ****** ;100mS DELAY (POWER UP DELAY FOR DISPLAY)</pre>                              |
| C009 9739<br>C00B 8602<br>C00D 9724<br>C00F 7F0028<br>C012 8E10FF<br>C015 8680<br>C017 9726<br>C019 86FC<br>C01B 9709<br>C01D 8600<br>C01F 9708<br>C021 7F002D<br>C027 962E<br>C029 4F<br>C02A 972F<br>C02C CEFFFF<br>C02F FF4004<br>C032 CE2710<br>C035 BDC0E1                             | ;*******<br>ONSCI:<br>;*******<br>ONPIA:<br>;******* | STAA<br>LDAA<br>STAA<br>CLR<br>LDS<br>LDAA<br>STAA<br>INITIAL<br>LDAA<br>STAA<br>CLR<br>CLR<br>CLR<br>CLR<br>CLR<br>STAA<br>INITIAL<br>LDA<br>STAA<br>INITIAL<br>LDX<br>STX<br>DISPLAY<br>LDX<br>JSR         | OPTION<br>#002H<br>TMSK2<br>SPCR<br>#STACK<br>#080H<br>PACTL<br>IZE THE SCI<br>#0FCH<br>DDRD<br>#000H<br>PORTD<br>SCCR1<br>SCCR2<br>SCSR<br>IZE THE 301<br>#0FFFFH<br>PORTBC+4<br>SET UP (NEW<br>#02710H<br>TDELAY | <pre>IRQE = 1 ;(ENABLE EEPROM CHARGE PUMP, IRQ EDGE SENSITIVE) ;SET TIMER PRESCALER TO 8 ;AND DISABLE TIMER INTERRUPTS ;DISABLE ALL SPI INT. ;SET UP STACK ;PA7 OUTPUT TO 9600 BAUD AT 8MHZ (DISABLED) ;INIT. PORT D DDR (02H) ;PD0, PD1 - INPUT, PD2-PD5 - OUTPUT ;SET UP PORT D ;SET UP SER. COM. CON. REG. 1 ;TO CLEAR TDRE AND TC OF SCSR ;READ STATUS REG., LOAD TRANS. DATA REG. FOR DISPLAY INTERFACE ;SET UP PORTS B &amp; C AS OUTPUTS V REV. 15 MAY 91) ****** ;100mS DELAY (POWER UP DELAY FOR DISPLAY) ;TIME DELAY</pre>                  |
| C009 9739<br>C00B 8602<br>C00D 9724<br>C00F 7F0028<br>C012 8E10FF<br>C015 8680<br>C017 9726<br>C019 86FC<br>C01B 9709<br>C01D 8600<br>C01F 9708<br>C021 7F002C<br>C024 7F002D<br>C027 962E<br>C029 4F<br>C02A 972F<br>C02C CEFFFF<br>C02F FF4004<br>C032 CE2710<br>C035 BDC0E1<br>C038 8630 | ;*******<br>ONSCI:<br>;*******<br>ONPIA:<br>;******* | STAA<br>LDAA<br>STAA<br>CLR<br>LDS<br>LDAA<br>STAA<br>INITIAL<br>LDAA<br>STAA<br>CLR<br>CLR<br>CLR<br>CLR<br>CLR<br>STAA<br>INITIAL<br>LDX<br>STX<br>DISPLAY<br>LDX                                          | OPTION<br>#002H<br>TMSK2<br>SPCR<br>#STACK<br>#080H<br>PACTL<br>IZE THE SCI<br>#0FCH<br>DDRD<br>#000H<br>PORTD<br>SCCR1<br>SCCR2<br>SCSR<br>SCDR<br>IZE THE 301<br>#0FFFFH<br>PORTBC+4<br>SET UP (NEW<br>#02710H   | <pre>IRQE = 1 ;(ENABLE EEPROM CHARGE PUMP, IRQ EDGE SENSITIVE) ;SET TIMER PRESCALER TO 8 ;AND DISABLE TIMER INTERRUPTS ;DISABLE ALL SPI INT. ;SET UP STACK ;PA7 OUTPUT TO 9600 BAUD AT 8MHZ (DISABLED) ;INIT. PORT D DDR (02H) ;PD0, PD1 - INPUT, PD2-PD5 - OUTPUT ;SET UP PORT D ;SET UP SER. COM. CON. REG. 1 ;TO CLEAR TDRE AND TC OF SCSR ;READ STATUS REG., LOAD TRANS. DATA REG. FOR DISPLAY INTERFACE ;SET UP PORTS B &amp; C AS OUTPUTS N REV. 15 MAY 91) ****** ;100mS DELAY (POWER UP DELAY FOR DISPLAY)</pre>                              |
| C009 9739<br>C00B 8602<br>C00D 9724<br>C00F 7F0028<br>C012 8E10FF<br>C015 8680<br>C017 9726<br>C019 86FC<br>C01B 9709<br>C01D 8600<br>C01F 9708<br>C021 7F002D<br>C027 962E<br>C029 4F<br>C02A 972F<br>C02C CEFFFF<br>C02F FF4004<br>C032 CE2710<br>C035 BDC0E1                             | ;*******<br>ONSCI:<br>;*******<br>ONPIA:<br>;******* | STAA<br>LDAA<br>STAA<br>CLR<br>LDS<br>LDAA<br>STAA<br>INITIAL<br>LDAA<br>STAA<br>CLR<br>CLR<br>CLR<br>CLR<br>CLR<br>STAA<br>INITIAL<br>LDA<br>STAA<br>INITIAL<br>LDX<br>STX<br>DISPLAY<br>LDX<br>JSR         | OPTION<br>#002H<br>TMSK2<br>SPCR<br>#STACK<br>#080H<br>PACTL<br>IZE THE SCI<br>#0FCH<br>DDRD<br>#000H<br>PORTD<br>SCCR1<br>SCCR2<br>SCSR<br>IZE THE 301<br>#0FFFFH<br>PORTBC+4<br>SET UP (NEW<br>#02710H<br>TDELAY | <pre>IRQE = 1 ;(ENABLE EEPROM CHARGE PUMP, IRQ EDGE SENSITIVE) ;SET TIMER PRESCALER TO 8 ;AND DISABLE TIMER INTERRUPTS ;DISABLE ALL SPI INT. ;SET UP STACK ;PA7 OUTPUT TO 9600 BAUD AT 8MHZ (DISABLED) ;INIT. PORT D DDR (02H) ;PD0, PD1 - INPUT, PD2-PD5 - OUTPUT ;SET UP PORT D ;SET UP SER. COM. CON. REG. 1 ;TO CLEAR TDRE AND TC OF SCSR ;READ STATUS REG., LOAD TRANS. DATA REG. FOR DISPLAY INTERFACE ;SET UP PORTS B &amp; C AS OUTPUTS V REV. 15 MAY 91) ******* ;100mS DELAY (POWER UP DELAY FOR DISPLAY) ;TIME DELAY ;SET UP DISPLAY</pre> |
| C009 9739<br>C00B 8602<br>C00D 9724<br>C00F 7F0028<br>C012 8E10FF<br>C015 8680<br>C017 9726<br>C019 86FC<br>C01B 9709<br>C01D 8600<br>C01F 9708<br>C021 7F002C<br>C024 7F002D<br>C027 962E<br>C029 4F<br>C02A 972F<br>C02C CEFFFF<br>C02F FF4004<br>C032 CE2710<br>C035 BDC0E1<br>C038 8630 | ;*******<br>ONSCI:<br>;*******<br>ONPIA:<br>;******* | STAA<br>LDAA<br>STAA<br>CLR<br>LDS<br>LDAA<br>STAA<br>INITIAL<br>LDAA<br>STAA<br>CLR<br>CLR<br>CLR<br>CLR<br>CLR<br>STAA<br>INITIAL<br>LDA<br>STAA<br>INITIAL<br>LDX<br>STX<br>DISPLAY<br>LDX<br>JSR<br>LDAA | OPTION<br>#002H<br>TMSK2<br>SPCR<br>#STACK<br>#080H<br>PACTL<br>IZE THE SCI<br>#000H<br>PORTD<br>SCCR1<br>SCCR2<br>SCSR<br>SCDR<br>IZE THE 301<br>#0FFFFH<br>PORTBC+4<br>SET UP (NEV<br>#02710H<br>TDELAY<br>#030H | <pre>IRQE = 1 ;(ENABLE EEPROM CHARGE PUMP, IRQ EDGE SENSITIVE) ;SET TIMER PRESCALER TO 8 ;AND DISABLE TIMER INTERRUPTS ;DISABLE ALL SPI INT. ;SET UP STACK ;PA7 OUTPUT TO 9600 BAUD AT 8MHZ (DISABLED) ;INIT. PORT D DDR (02H) ;PD0, PD1 - INPUT, PD2-PD5 - OUTPUT ;SET UP PORT D ;SET UP SER. COM. CON. REG. 1 ;TO CLEAR TDRE AND TC OF SCSR ;READ STATUS REG., LOAD TRANS. DATA REG. FOR DISPLAY INTERFACE ;SET UP PORTS B &amp; C AS OUTPUTS V REV. 15 MAY 91) ****** ;100mS DELAY (POWER UP DELAY FOR DISPLAY) ;TIME DELAY</pre>                  |

The PSD311 simplifies an eight wire cable tester design and increases flexibility in the process

| Appendix B. C            | ore Syste | m Softwa     | are for       |                                          |
|--------------------------|-----------|--------------|---------------|------------------------------------------|
| Cable Tester D           | esign (Co | nt.)         |               |                                          |
| C040 BDC0E1              | • •       | JSR          | TDELAY        | TIME DELAY                               |
| C043 BDC0F4              |           | JSR          | SENDI         | SEND INSTRUCTION (30 2ND TIME)           |
| C046 BDC0DE              |           | JSR          | TD40          | ; TIME DELAY                             |
| C049 BDC0F4              |           | JSR          | SENDI         | SEND INSTRUCTION (30 3RD TIME)           |
| C04C BDC0DE              |           | JSR          | TD40          | TIME DELAY                               |
| C04F 8638                |           | LDAA         | #038H         | ; FUNCTION SET (8 BIT-SINGLE LINE)       |
| C051 BDC0F4              |           | JSR          | SENDI         | ; SEND INSTRUCTION                       |
| C054 CE0280              |           | LDX          | #00280H       | ; 5mS DELAY                              |
| C057 BDC0E1              |           | JSR          | TDELAY        | TIME DELAY                               |
| C05A 860C                |           | LDAA         | #00CH         | DISPLAY ON - NO CURSOR                   |
| C05C BDC0F4              |           | JSR          | SENDI         | ; SEND INSTRUCTION                       |
| C05F CE0280              |           | LDX          | #00280H       | 5mS DELAY                                |
| C062 BDC0E1              |           | JSR          | TDELAY        | TIME DELAY                               |
| C065 8606                |           | LDAA         | #006H         | ;ENTRY MODE SET                          |
| C067 BDC0F4              |           | JSR          | SENDI         | SEND INSTRUCTION                         |
| C06A CE0280              |           | LDX          | #00280H       | 5mS DELAY                                |
| CO6D BDC0E1              |           | JSR          | TDELAY        | TIME DELAY                               |
| C070 BDC0EC              |           | JSR          | HOME          | DISPLAY CURSOR HOME!                     |
| C073 CE0190              |           | LDX          | #00190H       | 4.0mS DELAY                              |
| C076 BDC0E1              |           | JSR          | TDELAY        | TIME DELAY                               |
| C079 18CE6000            |           | LDY          | #DATTAB       | TOP OF DATA TABLE                        |
| C07D BDC0CC              |           | JSR          | PDOD          | SEND MESSAGE TO DISPLAY                  |
|                          | ;*****    |              | INIT. ******  |                                          |
| C080 9629                | FINIT:    | LDAA         | SPSR          | CLEAR ANY SPI INT.                       |
| C082 962A                |           | LDAA         | SPDR          | •                                        |
| C084 86FF                |           | LDAA         | #OFFH         | CLEAR ANY TIMER INT.                     |
| C086 9723                |           | STAA         | TFLG1         |                                          |
| C088 9725                |           | STAA         | TFLG2         |                                          |
| C08A 962E                |           | LDAA         | SCSR          | CLEAR ANY SCI INT.                       |
| C08C 962F                |           | LDAA         | SCDR          |                                          |
|                          | ;         |              |               |                                          |
| 0000 700000              | EXAMPLE   |              |               | TCH AND BUFFER                           |
| C08E 7F2000              |           | CLR          | LAT           | CLEAR LATCH                              |
| C091 CE1001              |           | LDX          | #LA1          | SET INDEX                                |
| C094 1C0200<br>C097 A600 |           | BSET         | 2,X,00H       | ;SET BIT 2 OF LA1<br>;GET LATCH REGISTER |
| C099 B72000              |           | ldaa<br>Staa | 0,X<br>LAT    | STORE DATA TO LATCH                      |
| C09C B62000              |           |              |               |                                          |
| CU9C B02000              |           | LDAA         | LAT           | ;GET DATA FROM BUFFER                    |
| C09F BDC0B0              | 7         | JSR          | BEEP          | ;SOUND OFF!                              |
| 0071 000000              | ;         | UDI          | 0001          | <i>Joodab</i> 011.                       |
| COA2 OE                  | ,         | CLI          |               | CLEAR IRQ MASK                           |
|                          | ;         |              |               | ,                                        |
|                          | ******    | ******       | *****         |                                          |
|                          | ; *       | MAIN L       | 00P *         |                                          |
|                          | ******    |              | ******        |                                          |
|                          | ;         |              |               |                                          |
| C0A3 01                  | LOOP:     | NOP          |               |                                          |
| COA4 7ECOA3              |           | JMP          | LOOP          | ; RETURN                                 |
|                          | ;         |              |               | •                                        |
|                          | ;******   | ******       | ********      | ******                                   |
|                          | ;*        | SUBROU       |               | *                                        |
|                          | ;******   | ******       | *********     | * * * * * * * *                          |
|                          | ;         |              |               |                                          |
|                          | ******    | WATCHD       | OG SERVICE RO | UTINE *****                              |
| C0A7 8655                | DOG:      | LDAA         | #055H         | ;RESET WATCHDOG TIMER                    |
| C0A9 973A                |           | STAA         | COPRST        | •                                        |
| COAB 86AA                |           | LDAA         | #0AAH         |                                          |
| COAD 973A                |           | STAA         | COPRST        |                                          |
| COAF 39                  |           | RTS          |               | ;RETURN FROM SUB.                        |
|                          |           |              |               |                                          |

#### Appendix B. Core System Software for Cable Tester Design (Cont.) \*\*\*\*\*\*\* HOOTER OSC. ROUTINE \*\*\*\*\*\*\* COBO 18CE01FF BEEP: #001FFH ;SET COUNT LDY C0B4 8640 BEEP1: LDAA #040H ; BEEPER ON C0B6 9700 STAA PORTA C0B8 CE0014 LDX #00014H COBB BDCOE1 JSR TDELAY ; DELAY COBE 4F CLRA ; BEEPER OFF C0BF 9700 STAA PORTA C0C1 CE0014 LDX #00014H COC4 BDC0E1 JSR TDELAY ; DELAY C0C7 1809 ;COUNT -1 DEY C0C9 26E9 BNE BEEP1 ; IF NOT DONE, KEEP GOING COCB 39 RTS ; RETURN FROM SUB. ; ;\*\*\*\*\*\*\* PUT DATA ON DISPLAY \*\*\*\*\*\*\* COCC 18A600 PDOD: LDAA 0,Y ;GET BYTE COCF 2707 BEQ PDOD1 ; IF END, GOTO NEXT1 COD1 BDC100 JSR SENDD C0D4 1808 ;NEXT BYTE INY C0D6 20F4 BRA PDOD ; RETURN TO NEXT C0D8 39 PDOD1: RTS ; RETURN FROM SUB. ;\*\*\*\*\*\* TIME DELAY ROUTINE \*\*\*\*\*\*\*\* C0D9 CE0002 TD20: LDX #00002H ;20uS DELAY C0DC 2003 BRA TDELAY TD40: CODE CEOOOF LDX #0000FH ;150uS DELAY ; DECRAMENT COUNT C0E1 09 TDELAY: DEX #00000н` ; COUNT = 0? C0E2 8C0000 CPX COE5 26FA ; IF NOT DONE, GOTO TDELAY BNE TDELAY C0E7 39 RTS ; RETURN FRO SUB. ;\*\*\*\*\*\* CLEAR SCREEN, CURSOR HOME, AND SEND INSTRUCTION \*\*\*\*\*\* C0E8 8601 CSCREEN: LDAA #001H ;CLEAR DISPLAY ;SEND INSTRUCTION C0EA 2008 BRA SENDI C0EC 8602 ;CURSOR HOME HOME : LDAA #002H C0EE 2004 SENDI BRA ;SEND INSTRUCTION #0C0H COF0 86C0 LINE2: LDAA ;SET CURSOR TO LINE 2 COF2 2000 COF4 CE4000 SENDI: ; SEND INSTRUCTION BRA LDX STAA BSET SENDI ;SET UP DATA TRANSFER #PORTBC STORE AT PIA PORT A C0F7 A706 6,X 7,X,02H C0F9 1C0702 ;DISPLAY E HIGH DISPLAY E LOW COFC 1D0702 BCLR 7,X,02H COFF 39 RTS ; RETURN FROM SUB. ;\*\*\*\*\*\* SEND DATA TO DISPLAY \*\*\*\*\*\*\* C100 CE4000 SENDD: LDX #PORTBC ; SET UP DATA TRANSFER ; SEND DATA 6,X C103 A706 STAA ; DISPLAY RS HIGH C105 1C0701 BSET 7,X,01H ;DISPLAY E HIGH C108 1C0702 BSET 7,X,02H C10B 1D0702 BCLR 7,X,02H ; DISPLAY E LOW C10E 1D0701 BCLR 7,X,01H ;DISPLAY RS LOW C111 BDC0DE TD40 ;150uS TIME DELAY JSR ; RETURN FROM SUB. C114 39 RTS ; ;\* ROUTINE TO CHANGE BYTE IN EEROM ;\* PRELOADED X = ADDRESS IN EEROM (B600 - B7FF) \* ;\* DATA TO BE STORED, IS IN "STOR" ;\* (THIS IS A MOTOROLA ROUTINE)

| Appendix B. | Core System Software for |
|-------------|--------------------------|
|             | Design (Cont.)           |

| C115 A600<br>C117 81FF<br>C119 2717<br>C11B 8616<br>C11D 973B<br>C11F 86FF<br>C121 A700 |               | LDAA<br>CMPA<br>BEQ<br>LDAA<br>STAA<br>LDAA<br>STAA | 0,X<br>#0FFH<br>CHGBYT1<br>#016H<br>PPROG<br>#0FFH<br>0,X | ;GET DATA AT ADDRESS TO BE CHANGED<br>;CHECK IF ERASED<br>;JUMP IF BYTE ERASED<br>;SET BYTE, ERASE, AND EELAT |
|-----------------------------------------------------------------------------------------|---------------|-----------------------------------------------------|-----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|
| C123 8617<br>C125 973B                                                                  |               | LDAA<br>STAA                                        | #017H<br>PPROG                                            | ;SET EEPRG                                                                                                    |
| C127 3C                                                                                 |               | PSHX                                                | #00000                                                    | ;SAVE X                                                                                                       |
| C128 CE0300<br>C12B BDC0E1                                                              |               | LDX<br>JSR                                          | #00300H<br>Tdelay                                         | ;20ms TIME DELAY                                                                                              |
| C12E 38                                                                                 |               | PULX                                                |                                                           | ; RESTORE X                                                                                                   |
| Cl2F 4F                                                                                 |               | CLRA                                                |                                                           | CLEAR BYTE, ERASE, EELAT, AND EEPRG                                                                           |
| C130 973B<br>C132 8602                                                                  | QUCBYM1.      | STAA                                                | PPROG<br>#002H                                            | SEND OF BYTE ERASE                                                                                            |
| C134 973B                                                                               | CHGBYT1:      | STAA                                                | #002H<br>PPROG                                            | ;set eelat – do byte program                                                                                  |
| C136 B61002                                                                             |               | LDAA                                                | STOR                                                      | ;GET DATA TO BE STORED                                                                                        |
| C139 A700                                                                               |               | STAA                                                | 0,X                                                       | STORE IN NEW LOCATION IN EEROM                                                                                |
| C13B 7C003B<br>C13E 3C                                                                  |               | INC<br>PSHX                                         | PPROG                                                     | ;SAVE X                                                                                                       |
| Cl3F CE0300                                                                             |               | LDX                                                 | #00300H                                                   | ; SAVE A                                                                                                      |
| C142 BDC0E1                                                                             |               | JSR                                                 | TDELAY                                                    | ;20ms DELAY                                                                                                   |
| C145 38                                                                                 |               | PULX                                                |                                                           | ; RESTORE X                                                                                                   |
| C146 7A003B<br>C149 7F003B                                                              |               | DEC<br>CLR                                          | PPROG<br>PPROG                                            | CLEAR EEPRG<br>CLEAR EELAT, END OF BYTE PROGRAM                                                               |
| C14C 39                                                                                 |               | RTS                                                 | 11000                                                     | RETURN FROM SUB.                                                                                              |
|                                                                                         | ;<br>;******  |                                                     |                                                           | ****                                                                                                          |
|                                                                                         | ;*            |                                                     |                                                           | /D CONVERTER *                                                                                                |
|                                                                                         | ;*<br>;*      | BEFORE                                              | ENTRY TO THI                                              | TITATE CONVERSION                                                                                             |
| C14D 9730                                                                               | CONV:         |                                                     | ADCTL                                                     | ;SET UP A/D CONVERTER                                                                                         |
| C14F 133080FC<br>C153 39                                                                |               | BRCLR<br>RTS                                        |                                                           | CONV1 ; WAIT HERE TILL CONVERSION COMPLETE ; RETURN FROM SUB.                                                 |
|                                                                                         | ;             |                                                     |                                                           |                                                                                                               |
|                                                                                         |               |                                                     | ROUTINES                                                  | *                                                                                                             |
|                                                                                         | ******        |                                                     | ******                                                    | *                                                                                                             |
|                                                                                         | ;*****        | ******                                              | *******                                                   | ******                                                                                                        |
|                                                                                         | ;*<br>;****** | SERIAL                                              | COMMUNICATIO                                              | NS INTERFACE - IRQ *<br>*****************************                                                         |
| C154 3B                                                                                 | ;<br>SCOM:    | RTI                                                 |                                                           | RETURN FROM INT.                                                                                              |
|                                                                                         | ;*****        | ******                                              | ********                                                  | ***                                                                                                           |
|                                                                                         | ;* SERI       | AL TRANS                                            | FER COMPLETE                                              | *                                                                                                             |
| C155 3B                                                                                 | ;<br>TRANC:   | RTI                                                 |                                                           | ;RETURN FROM INT.                                                                                             |
|                                                                                         | ;             |                                                     |                                                           |                                                                                                               |
|                                                                                         |               |                                                     | ATOR INPUT E                                              |                                                                                                               |
|                                                                                         | ;******       | *******                                             | *****                                                     | *****                                                                                                         |
| C156 3B                                                                                 | PULSEE:       | RTI                                                 |                                                           | RETURN FROM INT.                                                                                              |
|                                                                                         | ;<br>;******  | ******                                              | *********                                                 | ****                                                                                                          |
|                                                                                         | * PULS        | E ACCUMU                                            | LATOR OVERFI                                              | -ow *                                                                                                         |
|                                                                                         | ;******       | ******                                              | **********                                                | ****                                                                                                          |
|                                                                                         |               |                                                     |                                                           |                                                                                                               |

| C161 |    | ;<br>REALT:<br>; | RTI                                    | RETURN I  | FROM I  | NT.           |
|------|----|------------------|----------------------------------------|-----------|---------|---------------|
|      |    | * REAL           |                                        | *         |         |               |
| 0100 |    | ;                | *****                                  | •         | KOPI I  |               |
| C160 | 38 | ;                | ************************************** | ;RETURN I | י אַרַק | NT            |
|      |    | ;* TIMER         | R INPUT COMPARE 1 *                    |           |         |               |
| CIDE | 55 | ;                | KII<br>*****                           | ; RETORN  | rom     | 7UT .         |
| C15F | 38 | ;                | ************************************** | ; RETURN  | FROM    | тእጥ           |
|      |    | ;* TIMEF         | R INPUT COMPARE 2 *                    |           |         |               |
|      |    | ; *******        | *****                                  |           |         |               |
| C15E | 3B |                  | RTI                                    | ; RETURN  | FROM    | INT.          |
|      |    | ;*******         | ************************************** |           |         |               |
|      |    |                  | ************************************** |           |         |               |
| C15D | 3B | COMP1:           | RTI                                    | ; RETURN  | FROM    | INT.          |
|      |    | ;*******         | ************************************** | *         |         |               |
|      |    | •                | COUTPUT COMPARE 1                      | *         |         |               |
| C15C | 38 | COMP2:           | RTI                                    | ; RETURN  | FROM    | TNT.          |
| 0150 | 28 | ;                |                                        |           | FROM    | <b>T</b> \100 |
|      |    |                  | COUTPUT COMPARE 2                      | *         |         |               |
|      |    | ;******          | *****                                  | *         |         |               |
| С15В | 3B | ;<br>COMP3:      | RTI                                    | ; RETURN  | FROM    | INT.          |
|      |    | ;* TIMEF         | R OUTPUT COMPARE 3                     | *         |         |               |
|      |    | *******          |                                        | *         |         |               |
| C15A | 3B | COMP4:           | RTI                                    | ; RETURN  | FROM    | INT.          |
|      |    | ;******          | *****                                  |           |         |               |
|      |    | * TIMER          | ************************************** |           |         |               |
|      |    | ;                |                                        | •         |         |               |
| C159 | 3в | COMP5:           | RTI                                    | ; RETURN  | FROM    | INT.          |
|      |    |                  | R OUTPUT COMPARE 5                     |           |         |               |
|      |    | ******           | *****                                  |           |         |               |
| C158 | 3B | TIMEO:           | RTI                                    | ; RETURN  | FROM    | INT.          |
|      |    |                  | R OVERFLOW *                           |           |         |               |
|      |    |                  | *****                                  |           |         |               |
| C157 | 3B | PULSEO:          | RTI                                    | ; RETURN  | FROM    | INT.          |
|      |    | :                |                                        |           |         |               |

|                        | ;*******<br>;* IRQ :<br>;****** | INT. ROU           | TINE *           |                                                       |
|------------------------|---------------------------------|--------------------|------------------|-------------------------------------------------------|
| <br>960A<br>840F       | ;<br>DOIT:                      | LDAA<br>ANDA       | PORTE<br>#00FH   | ;GET KEYBOARD DATA<br>;FILTER DATA                    |
| <br>8100<br>2601<br>3B | ;                               | CMPA<br>BNE<br>RTI | #KEY1<br>DOIT10  | ;1 KEY?<br>;IF NOT GOTO DOIT10<br>;RETURN FROM INT.   |
| <br>8101<br>2601<br>3B | ;<br>DOIT10:                    | CMPA<br>BNE<br>RTI | #KEY2<br>DOIT20  | ;2 KEY?<br>;1F NOT GOTO DOIT20<br>;RETURN FROM INT.   |
| <br>8102<br>2601<br>3B | DOIT20:                         | CMPA<br>BNE<br>RTI | #KEY3<br>Doit30  | ;3 KEY?<br>;IF NOT, GOTO DOIT30<br>;RETURN FROM INT.  |
| <br>8103<br>2601<br>3B | DOIT30:                         | CMPA<br>BNE<br>RTI | #KEYA<br>DOIT40  | ;A KEY?<br>;IF NOT GOTO DOIT40<br>;RETURN FROM INT.   |
| 8104<br>2601<br>3B     | DOIT40:                         | CMPA<br>BNE<br>RTI | #KEY4<br>Doit50  | ;4 KEY?<br>;1F NOT GOTO DOIT50<br>;RETURN FROM INT.   |
| 8105<br>2601<br>3B     | ;<br>DOIT50:                    | CMPA<br>BNE<br>RTI | #KEY5<br>Doit60  | ;5 KEY?<br>;1f not goto doit60<br>;Return from int.   |
| <br>8106<br>2601<br>3B | ;<br>DOIT60:                    | CMPA<br>BNE<br>RTI | #KEY6<br>Doit70  | ;6 KEY?<br>;1f not goto doit70<br>;Return from int.   |
| 8107<br>2601<br>3B     | DOIT70:                         | CMPA<br>BNE<br>RTI | #KEYB<br>Doit80  | ;B KEY?<br>;IF NOT GOTO DOIT80<br>;RETURN FROM INT.   |
| 8108<br>2601<br>3B     | ;<br>DOIT80:                    | CMPA<br>BNE<br>RTI | #KEY7<br>Doit90  | ;7 KEY?<br>;1F NOT GOTO DOIT90<br>;RETURN FROM INT.   |
| <br>8109<br>2601<br>3B | ;<br>DOIT90:                    | CMPA<br>BNE<br>RTI | #KEY8<br>DOIT100 | ;8 KEY?<br>;IF NOT GOTO DOIT100<br>;RETURN FROM INT.  |
| <br>810A<br>2601<br>3B | DOIT100:                        | CMPA<br>BNE<br>RTI | #KEY9<br>DoIT110 | ;9 KEY?<br>;IF NOT GOTO DOIT110<br>;RETURN FROM INT.  |
| <br>810B<br>2601<br>3B | ;<br>DOIT110:                   | CMPA<br>BNE<br>RTI | #KEYC<br>DOIT120 | C KEY?<br>; IF NOT GOTO DOIT120<br>; RETURN FROM INT. |
| <br>810C<br>2601<br>3B | ;<br>DOIT120:                   | CMPA<br>BNE<br>RTI | #KEYZ<br>DOIT130 | ;* KEY?<br>;IF NOT GOTO DOIT130<br>;RETURN FROM INT.  |

| C1A7 810D<br>C1A9 2601<br>C1AB 3B | ;<br>DOIT130:        | CMPA<br>BNE<br>RTI | #KEY0<br>DOIT140                             | ;0 KEY?<br>;1F NOT GOTO DOIT140<br>;RETURN FROM INT. |
|-----------------------------------|----------------------|--------------------|----------------------------------------------|------------------------------------------------------|
| C1AC 810E<br>C1AE 2601<br>C1B0 3B | DOIT140:             | CMPA<br>BNE<br>RTI | #KEYY<br>DOIT150                             | ;# KEY?<br>;IF NOT GOTO DOIT150<br>;RETURN FROM INT. |
| C1B1 810F<br>C1B3 2600<br>C1B5 3B | DOIT150:<br>DOIT160: | BNE                | #KEYD<br>DOIT160                             | ;D KEY?<br>;IF NOT GOTO DOIT160<br>;RETURN FROM INT. |
|                                   | ;******<br>;* XIRQ   | SERVIC             | **************<br>E ROUTINE<br>************* | *                                                    |
| C1B6 3B                           | NOMASK:              | RTI                |                                              | ;RETURN FROM INT.                                    |
|                                   | ;                    | ******             | *****                                        | ****                                                 |
|                                   |                      |                    | ROUTINE                                      | *                                                    |
|                                   |                      |                    | *****                                        | ****                                                 |
| C1B7 3B                           | INTER:               | RTI                |                                              | ;RETURN FROM INT.                                    |
|                                   |                      |                    |                                              |                                                      |
|                                   |                      |                    | **************************************       |                                                      |
|                                   |                      |                    | ***************                              |                                                      |
|                                   | ;                    |                    |                                              |                                                      |
| FFC0                              | ,                    | ORG                | OFFCOH                                       |                                                      |
|                                   | ;                    |                    |                                              |                                                      |
| FFC0                              | RES:                 | DFS                | 11*2                                         | ;NOT USED                                            |
| FFD6 C154                         | SERCOM:              |                    | SCOM                                         | ;SERIAL COMM. INT.                                   |
| FFD8 C155                         | SPISTC:              |                    | TRANC                                        | ;SERIAL TRANSFER COMPLETE                            |
| FFDA C156                         | PAIE:                | DWM                | PULSEE                                       | ; PULSE ACCUMLATOR INPUT EDGE                        |
| FFDC C157<br>FFDE C158            | PAOV:<br>TOV:        | DWM<br>DWM         | PULSEO                                       | ; PULSE ACCUMULATOR OVERFLOW                         |
| FFE0 C159                         | TOCP5:               |                    | TIMEO<br>COMP5                               | ;TIMER OVERFLOW<br>;TIMER OUTPUT COMPARE 5           |
| FFE2 C15A                         | TOCP4:               |                    | COMP4                                        | TIMER OUTPUT COMPARE 5                               |
| FFE4 C15B                         | TOCP3:               |                    | COMP3                                        | TIMER OUTPUT COMPARE 3                               |
| FFE6 C15C                         |                      | DWM                | COMP2                                        | TIMER OUTPUT COMPARE 2                               |
| FFE8 C15D                         | TOCP1:               |                    | COMP1                                        | TIMER OUTPUT COMPARE 1                               |
| FFEA C15E                         | TICP3:               | DWM                | ICOMP3                                       | TIMER INPUT COMPARE 3                                |
| FFEC C15F                         | TICP2:               | DWM                | ICOMP2                                       | ;TIMER INPUT COMPARE 2                               |
| FFEE C160                         | TICP1:               |                    | ICOMP1                                       | ;TIMER INPUT COMPARE 1                               |
| FFF0 C161                         | RTIME:               | DWM                | REALT                                        | ;REAL-TIME INT.                                      |
| FFF2 C162                         | IRQ:                 | DWM                | DOIT                                         | ;TIMER/VIA INT.                                      |
| FFF4 C1B6<br>FFF6 C1B7            | XIRQ:                | DWM<br>DWM         | NOMASK<br>INTER                              | ; NON-MASKABLE INT.                                  |
| FFF8 C000                         | SWI:<br>IOT:         | DWM                | START                                        | ;SOFTWARE INT.<br>;ILLEGAL OPCODE TRAP (START OVER)  |
| FFFA C000                         | COPS:                | DWM                | START                                        | COP FAILURE (RESET)                                  |
| FFFC C000                         | COPS1:               | DWM                | START                                        | COP CLOCK MONITOR FAIL (RESET)                       |
| FFFE C000                         | RESET:               |                    | START                                        | RESET                                                |
|                                   | ;                    |                    |                                              | ·                                                    |
|                                   | ******               | ******             | *****                                        | ******                                               |
| 0000                              |                      | END                |                                              | THE ENDIIIII                                         |
|                                   |                      |                    |                                              |                                                      |

PSD3XX

## Benefits of 16-bit design with PSD3XX

By Ching Lee - WSI

| Introduction                                                | Embedded controller architecture has been<br>evolving from 4-bit, 8-bit to 16-bit through<br>the years. The increase in the data bus<br>bandwidth is a natural progression for<br>microcontrollers to achieve higher<br>performance. Today, 16-bit embedded<br>controllers such as the 80C196 and 683XX<br>families provide excellent performance at<br>reasonable cost. Yet many designers are<br>weary of the cost of higher chip count,<br>more board space and power consumption<br>in 16-bit applications and prefer to stay with<br>8-bit designs. Some microcontroller<br>manufacturers tackle this problem by<br>introducing processors with 16-bit internal<br>architectures but have 8-bit external data<br>busses. Later additional enhancements<br>such as dynamic bus sizing provide the<br>choice of selecting either an 8 or 16-bit bus<br>for further cost reduction. This compromise                                                                                                                               | certainly increases the performance; it is<br>still not as good as a true 16-bit implemen-<br>tation.<br>With the introduction of the PSD3XX family<br>of field programmable microcontroller<br>peripherals from WSI, there is no reason<br>not to use 16-bit microcontrollers. The<br>PSD3XX provides an integrated solution in<br>a single chip, which includes user<br>configurable I/O ports, Chip Select outputs,<br>logic replacement, Page Register,<br>Programmable Address Decoder (PAD),<br>EPROM and SRAM. The PSD3XX is a<br>perfect match for 16-bit microcontroller<br>applications. In this application note, we will<br>look at some of the advantages of 16-bit<br>designs, and how PSD3XX interfaces to<br>microcontrollers such as the 80C196 and<br>68302. |
|-------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Typical 16-Bit<br>Microcontroller<br>System<br>Architecture | There is no one standard 16-bit<br>architecture, especially in the field of<br>embedded controller applications. For a<br>typical 80C196 design, the basic building<br>block consists of two address latches<br>(74AC373), address decoding logic (with<br>PAL or discrete logic), program memory<br>(EPROMs), data memory (one or more<br>SRAM), and I/O devices.<br>Figure 1 is the schematic of such a system.<br>In this design, 64K bytes of program<br>memory/EPROM, and a 2K byte SRAM for<br>scratch pad are required. Since the<br>80C196 has only 64K byte memory space,<br>the INST signal provides the paging<br>capability, with program memory residing in<br>the first 64K page while SRAM and I/O<br>devices occupy the second page. The I/O<br>section consists of one output port<br>(74AC374) and other peripheral devices.<br>The chip select signals for the I/O devices<br>and memory are connected directly from<br>the decoding PAL outputs. The processor's<br>data bus width is determined by the type of | bus cycle. EPROM accesses are 16-bits<br>wide, SRAM is 8-bits while I/O bus cycles<br>can be 8 or 16-bits, depending on the<br>device being accessed. The BWIDTH<br>output from the PAL informs the processor<br>what type of bus width is to be expected for<br>that particular cycle.<br>An I/O device usually takes longer time to<br>complete the bus cycle. Let us assume, in<br>this case, I/O devices require 3 wait states<br>with the exception of the I/O latch. The<br>configuration register of the 80C196 is then<br>programmed to insert 3 wait states.<br>Whenever there is an I/O bus cycle, the<br>READY output signal from the PAL goes<br>low to activate the programmed amount of<br>wait state. For memory bus cycles, no wait<br>state is inserted.      |





Application Note 020

PSD3XX

438

May, 1993

| Typical 16-Bit<br>Microcontroller<br>System<br>Architecture<br>(Cont.) | 80C196 microco<br>of the I/O device<br>0000H through (<br>207FH are reset<br>The remaining k<br>program/data m<br>I/O devices. EPI | emory address map of the<br>ontroller, and the addresses<br>es. Address locations<br>00FFH and 1FFEH through<br>rved for the microcontroller.<br>ocations can be used for<br>emory or memory mapped<br>ROM occupies the first 64K | resides inside the EPROM from<br>location 1000H to 17FFH. The 2K scratch<br>RAM and I/O starts from 4000H in the<br>second page.<br>The address map requires the following<br>PAL equations to be programmed to the<br>decoder PAL. The IO_CS lines are enabled<br>after ALE goes low. |
|------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                        |                                                                                                                                    | ogram codes start from<br>H, and a 2K look-up table                                                                                                                                                                               |                                                                                                                                                                                                                                                                                        |
|                                                                        | EPROMCS                                                                                                                            | = INST<br>+ INST/ * A15/ * A14/                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                        |
|                                                                        | RAMCS                                                                                                                              | = INST/ * A15/ * A14 * A13                                                                                                                                                                                                        | 3/ * A12/                                                                                                                                                                                                                                                                              |
|                                                                        | BWIDTH                                                                                                                             | = RAMCS<br>+ IO_CS0<br>+ IO_CS1<br>+ IO_LAT                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                        |
|                                                                        | READY                                                                                                                              | = IO_CS0<br>+ IO_CS1<br>+ IO_CS2<br>+ IO_CS3                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                        |
|                                                                        | IO_LAT<br>IO_CS0<br>IO_CS1<br>IO_CS2<br>IO CS3                                                                                     | <ul> <li>INST/ * WR * A15/ * A1</li> <li>INST/ * ALE/ * A15/ * A1</li> <li>INST/ * ALE/ * A15/ * A1</li> <li>INST/ * ALE/ * A15 * A1</li> <li>INST/ * ALE/ * A15 * A1</li> <li>INST/ * ALE/ * A15 * A1</li> </ul>                 | 4 * A13 * A12/ "I/O DEV.#0<br>4 * A13 * A12 "I/O DEV.#1<br>4/ * A13/* A12/ "I/O DEV.#2                                                                                                                                                                                                 |

| Table 1.<br>80C196<br>Memory Man | Device               | INST<br>(Page) | Address<br>(Hex) | Buswidth<br>(Bit) |
|----------------------------------|----------------------|----------------|------------------|-------------------|
| Memory Map                       | EPROM (Code)         | 1              | 2080 – FFFF      | 16                |
|                                  | EPROM (Table + Data) | Х              | 1000 – 27FF      | 16                |
|                                  | RAM                  | 0              | 4000 – 47FF      | 8                 |
|                                  | I/O_LATCH            | 0              | 5000             | 8                 |
|                                  | I/O_CS0              | 0              | 6000             | 8                 |
|                                  | I/O_CS1              | 0              | 7000             | 8                 |
|                                  | I/O_CS2              | 0              | 8000             | 16                |
|                                  | I/O_CS3              | 0              | 9000             | 16                |

#### *16-Bit Performance Advantages*

It is obvious that a 16-bit bus provides more performance than an 8-bit bus, at least the data bus bandwidth will double. The following factors contribute to the performance improvement:

#### **Program Code Fetch**

Instructions such as ANDB of the 80C196 consists of 4 bytes. In an 8-bit bus system it takes 4 bus cycles to fetch the instruction, while in 16-bit bus designs it takes only 2 bus cycles.

#### Data Fetch

For applications with high data transfer rate, where indexed or indirect references are frequently used, a 16-bit bus takes much less time to accomplish the same job.

#### *Queue Flush for Branch/Jump Instructions*

A pre-fetch queue usually speeds up instruction execution time by providing instructions to the Execution Unit in a timely manner. However there is a penalty which goes with the queue when a successful branch or jump instruction is executed. The queue has to be flushed, Program Counter to be reloaded, and new instructions to be fetched. A 16-bit bus helps to fill up the queue much faster. This is critical to system performance since Branch/Jump instructions are the most frequently used instructions in general.

#### Free Up The System Bus

The microcontroller reduces its number of operand fetches in a 16-bit bus, freeing the bus for other devices which share the same bus. In system which has a DMA Controller or Slave Processor sharing the same memory space with the microcontroller, the less usage of the memory bus will enhance system performance. Let us look at a sample program to calculate the differences in execution time between an 8 and a 16-bit bus. In the typical 16-bit design example above, there is a look-up table residing in the EPROM. A look-up table is a quick way for the program to provide an output to an I/O device based on the input value without getting into complex mathematical operations. The following program, which is published in Intel application note AP-248, does table look-up and interpolation.

Assuming the 80C196 queue is always full, to execute the following code takes 128 state times in a 16-bit bus. In an 8-bit bus, it takes 32 more state times just to fetch the codes and data, not including the time the microcontroller waits for the queue to be filled. The estimated performance penalty for an 8-bit bus in this application is at least 25%, and will certainly be more in the actual run time environment. The published statement from Intel is that it is difficult to measure the 8-bit bus performance penalty, but has shown to be up to 30%, depending on the instruction mix.

The 16-bit bus design will increase the system performance, especially for microcontrollers which usually don't have internal program cache or a pre-fetch pipeline queue to lessen the penalty caused by the bottle neck on the memory bus. The 80C196 has an internal 4 byte queue. This helps execution time but bus width still remains the critical factor.

PSD3XX

### Benefits of 16-bit design with PSD3XX

| Table                        | RSEG at             | 22H                     |            |             |              |                                                                                                     |
|------------------------------|---------------------|-------------------------|------------|-------------|--------------|-----------------------------------------------------------------------------------------------------|
| Look-up and<br>Interpolation | IN-VAL:<br>TABLE_LO |                         | dsb<br>dsw | 1<br>1<br>1 | ;Ac          | tual Input Value                                                                                    |
|                              | TABLE_HI<br>IN DIF: | GH:                     | dsw<br>dsw | 1<br>1      | ۰IJn         | per Input-Lower Input                                                                               |
|                              | IN DIFB:            |                         | equ        | IN DIF      |              | yte                                                                                                 |
|                              | TAB DIF:            |                         | dsw        | 1           |              | per Output- Lower Output                                                                            |
|                              | OUT:                |                         | dsw        | 1           | -            |                                                                                                     |
|                              | RESULT:             |                         | dsw        | 1           |              |                                                                                                     |
|                              | OUT_DIF:            |                         | dsl        | 1           | ;De          | lta Out                                                                                             |
|                              | CSEG at             | 2080н                   |            |             |              |                                                                                                     |
|                              | LD SI               | P, #100}                | n          |             |              |                                                                                                     |
|                              | Look:               |                         |            |             |              |                                                                                                     |
|                              |                     | L, IN_VA                | AL         |             |              | ad temp with Actual Value                                                                           |
|                              |                     | L, #3                   | 1110-      |             |              | vide the byte by 8                                                                                  |
|                              | ANDB A              | L, #1111                | LIIIUB     |             | ;Th          | usure AL is a word address<br>his effectively divides AL by 2<br>h AL = IN VAL/16                   |
|                              | LDBZE A             | X, AL                   |            |             |              | ad byte AL to word AX                                                                               |
|                              |                     |                         | W, TABLE   | [AX]        |              | -                                                                                                   |
|                              |                     |                         |            |             |              | BLE_LOW is loaded with the value<br>the table at table location AX                                  |
|                              | LD T                | ABLE_HIC                | GH, (TABL  | E+2) [AX]   | . [1] 7      | DIE UTCH is loaded with the velue                                                                   |
|                              |                     |                         |            |             | ;in          | BLE_HIGH is loaded with the value<br>a the table at table loc. AX+2<br>The next value in the table) |
|                              | SUB T               | AB DIF,                 | TABLE HI   | GH, TABL    |              |                                                                                                     |
|                              |                     | - '                     |            | •           |              | B_DIF=TABLE_HIGH - TABLE_LOW                                                                        |
|                              | ANDB I              | N_DIFB,                 | IN_VAL,    | #OFH        |              |                                                                                                     |
|                              |                     |                         |            |             |              | DIFB=least significant 4 bits of                                                                    |
|                              |                     |                         | U DIED     |             |              | VAL                                                                                                 |
|                              | LDBZE II<br>MUL O   |                         | IN DIF,    | TAB DIF     | , 10         | ad byte IN_DIFB to word IN_DIF                                                                      |
|                              |                     |                         |            |             | ;00          | tput difference =                                                                                   |
|                              |                     |                         |            |             |              | put_difference * Table_difference                                                                   |
|                              | SHRAL O             | UT_DIF,                 | #4         |             | ;Di          | vide by 16 (2**4)                                                                                   |
|                              | ADD O               | UT, OUT                 | DIF, TAB   | LE_LOW      | <b>.</b> .   |                                                                                                     |
|                              |                     |                         |            |             |              | d output difference to output                                                                       |
|                              | SHRA O              | UT, #4                  |            |             |              | enerated with truncated IN_VAL as input<br>bund to 12-bit answer                                    |
|                              |                     | UT, ZERO                | C          |             |              | bund up if $Carry = 1$                                                                              |
|                              | No_Inc:             |                         |            |             |              |                                                                                                     |
|                              | ST O                | מוייי סופיכו            | ית.        |             | • 6+         | OTA OUT to PESILT                                                                                   |
|                              |                     | UT, RESU<br>ook         | 501        |             |              | core OUT to RESULT<br>manch to "Look"                                                               |
|                              |                     | t 2100h                 |            |             |              |                                                                                                     |
|                              | Table:              | <i>C</i> TT <i>A</i> 00 |            | 0.011 0.1   | 0.017        | 4000U a base days for all h                                                                         |
|                              |                     |                         | •          | •           | 00н,<br>00н, | 4C00H ;A random function<br>7800H                                                                   |
|                              |                     |                         |            | •           | 00H,         | 6D00H                                                                                               |
|                              |                     |                         |            | •           | оон,         | 2200H                                                                                               |
|                              |                     |                         | 00н        |             | ,            |                                                                                                     |
|                              | END                 |                         |            |             |              |                                                                                                     |

#### *PSD3XX Solution for 16-Bit Microcontroller*

In this section, we will see how a single PSD302 is able to replace all the basic building blocks as shown in the design example in Figure 1. As seen from the block diagram (Figure 2.), the PSD302 provides the following functional blocks:

- 64K bytes EPROM, as 64K x 8 or 32K x 16
- 2K bytes SRAM, as 2K x 8 or 1K x 16, expanding the microcontroller's internal scratch SRAM
- Address latches/data buffers, bus interface to most microcontrollers.
- Programmable Address Decoder (PAD); provides PAL type function: 18 inputs, 24 outputs and 40 product terms.
- Port A: an 8-bit port, each bit can be configured as :
  - I/O line
  - latched address output (A0-A7)
  - track AD0/AD7 as I/O lines in track mode for shared access.
  - data port D0/D7 in non-multiplexed mode
  - CMOS or open drain output
- Port B: an 8-bit port, each bit can be configured as :
  - I/O line
  - chip select or logic replacement output from the PAD
  - D8-D15 in non-multiplexed mode
  - CMOS or open drain output

- Port C: 3-bit port, each bit can be configured as input to or output from the PAD
- Page Register: a 4-bit Page Register for bank switching
- □ A19/CSI input pin for power down configuration

Figure 3 is the schematic of the design example with the PSD302. Not all the functions of the PSD3XX are utilized in this example. The Page Register is not used since the INST signal from the 80C196 can be easily included in the PAD for page decoding (for design with the Page Register, see WSI Application Note 015). The internal EPROM and SRAM of the PSD302 replaces U5, U6, and U7 in Figure 1. Port A is configured as an I/O port to replace U3, the I/O latch. The PAD provides decoding functions for all the chip selects, as well as the READY and BWIDTH inputs to the microcontroller. Please note the PSD302 is able to provide a 16-bit SRAM for faster data accesses.

In this application the PSD302 is configured to operate in a 16-bit, multiplexed mode. The PAL equations are programmed into the PAD. Depending on the particular bus cycle, the PSD302 latches the microcontroller address, determines which device is to be enabled, and provides data output for a read cycle. If it is an I/O bus cycle, either Port A is enabled or one of the I/O\_CS lines are activated. At the same time, the appropriate READY and BWIDTH signals are generated.



#### Figure 3. Design Example with PSD302



**Application Note 020** 

**PSD3XX** 

### Benefits of 16-bit design with PSD3XX

| PSD3XX<br>Solution<br>for 16-Bit<br>Microcontroller<br>(Cont.) | WSI supplies PSD users with easy to use<br>software tools and programming devices.<br>MAPLE software, which is PC based,<br>enables designers to configure the<br>PSD3XX. Some of the computer screen<br>configuration displays for this design | example are shown in Figure 4. Figure 4A<br>is the address map decode for the<br>EPROM, SRAM and Port A. Figure 4B is<br>the truth table input for the READY signal. |
|----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|

| D3XX<br>dress |      | A<br>19 | A<br>18 | A<br>17   | A<br>16 | A<br>15       | A<br>14 | A<br>13 | A<br>12 | A<br>11 | SEGMT<br>Start | SEGMT<br>STOP | FILE<br>START       | FILE<br>STOP | FILE NAME |
|---------------|------|---------|---------|-----------|---------|---------------|---------|---------|---------|---------|----------------|---------------|---------------------|--------------|-----------|
| np            | ES0  | N       | 0       | х         | х       | 0             | 0       | 0       | N       | N       |                |               | 0                   | 1FFF         | TEST.HEX  |
|               | ES1  | N       | х       | х         | х       | 0             | 0       | 1       | Ν       | Ν       |                |               | 2000                | 3FFF         | TEST.HEX  |
|               | ES2  | Ň       | 1       | Х         | х       | 0             | 1       | 0       | Ν       | Ν       |                |               | 4000                | 5FFF         | TEST.HEX  |
|               | ES3  | Ν       | 1       | х         | х       | 0             | 1       | 1       | Ν       | Ν       |                |               | 6000                | 7FFF         | TEST.HEX  |
|               | ES4  | Ν       | 1       | Х         | х       | 1             | 0       | 0       | Ν       | N       |                |               | 8000                | 9FFF         | TEST.HEX  |
|               | ES5  | Ν       | 1       | Х         | х       | 1             | 0       | 1       | Ν       | Ν       |                |               | A000                | BFFF         | TEST.HEX  |
|               | ES6  | Ν       | 1       | Х         | х       | 1             | 1       | 0       | Ν       | Ν       |                |               | C000                | DFFF         | TEST.HEX  |
|               | ES7  | Ν       | 1       | Х         | х       | 1             | 1       | 1       | Ν       | Ν       |                |               | E000                | FFFF         | TEST.HEX  |
|               | RS0  | Ν       | 0       | х         | х       | 0             | 1       | 0       | 0       | 0       |                |               | N/A                 | N/A          | N/A       |
|               | CSP  | Ν       | 0       | Х         | х       | 0             | 1       | 0       | 1       | 0       |                |               | N/A                 | N/A          | N/A       |
|               | ALIA | S: A    | 18      | = 11      | IST     |               |         |         |         |         |                |               |                     |              | -         |
|               |      |         |         | 000000000 |         | 1997 - Barris |         |         |         |         | IT (Hex);      |               | (START<br>any field |              |           |

PART NAME: PSD302

PIN

PB0 PB1 PB2 PB3 PB4 PB5 PB6 PB7

C:\WSI\OLDMAP

Figure 4B. RĚADY Signal Truth Table

| 8 | CS/I/O<br>CS0 | CMOS/OD<br>CMOS |     |     | Сн  | IP SE | ELEC | T DE | FINI | rion | REA | DY |     |   |
|---|---------------|-----------------|-----|-----|-----|-------|------|------|------|------|-----|----|-----|---|
|   | CS1           | CMOS            | 440 |     | 440 |       |      |      | 440  |      | -   | wp |     |   |
| 2 | CS2           | смоз            | A18 | A17 |     | A15   | A14  | A13  | A12  | A11  | RD  | WR | ALE |   |
| ; | CS3           | смоз            | 0   | Х   | Х   | 0     | 1    | 1    | 0    | Х    | х   | X  | 0   | Х |
|   | CS4           | CMOS            | 0   | х   | х   | 0     | 1    | 1    | 1    | X    | х   | X  | 0   | Х |
| ; | CS5           | CMOS            | 0   | х   | х   | 1     | 0    | 0    | 0    | X    | х   | X  | 0   | X |
| ; | CS6           | CMOS            | 0   | х   | х   | 1     | 0    | 0    | 1    | X    | х   | x  | 0   | х |
| , | CS7           | смоз            |     |     | L   | = IN: | L    |      | L    |      |     | L  |     |   |

CS definition is the NOR of the product terms (rows). Enter 1 to select High signal, 0 to select Active Low signal, X to mean "don't care", SPACEBAR to erase. Enter values in columns relevant to your application; leave other columns untouched.

F1 - Return to PORT B Menu

Cursor - Upt

Down

Left -Right ↔

PART NAME: PSD302

445

PSD3XX

#### Benefits of 16-bit design with PSD3XX

# A PSD3XX can be configured to operate in the 16-bit mode with a non-multiplexed bus

*PSD3XX Solution for 16-Bit Processor with Non-Multiplexed Bus* 

the 16-bit mode with a non-multiplexed bus. In this case, the microcontroller address lines A0–A15 are tied to AD0–AD15 inputs of the PSD3XX; Port A and B of the PSD3XX are then configured as data ports, connecting to data bus D0–D15. In applications where the EPROM space in a PSD3XX is not enough, or a large amount of I/O lines and chip selects are needed, two PSD3XXs will provide a viable solution. Connecting two PSD3XXs to a microcontroller needs special consideration. Figure 5 shows a basic design of a 68302 microcontroller interfacing to two PSD312s. The implementation is fairly straightforward; the two PSD302's are configured to work in 8-bit non-multiplexed mode. The first PSD302 (U2) occupies the even bank of the memory space of the 68302; the second PSD302 (U3) occupies the odd bank. The 68302 has no A0 in the address bus; it depends on signals UDS/ and LDS/ (Upper and Lower Data Strobe) to control the flow of data on the data bus as shown in Table 2.

*Table 2. 68302 Byte Enable* 

| UDS/ | LDS/ | D8D15    | D0D7     |
|------|------|----------|----------|
| Low  | Low  | Enabled  | Enabled  |
| Low  | High | Enabled  | Disabled |
| High | Low  | Disabled | Enabled  |
| High | High | Disabled | Disabled |

The above table is also true for most other microcontrollers. Some use different signal names, such as HBE/ for UDS/ and A0 is equivalent to LDS/. The decoding for bank select is the same for both cases. The following points must be considered when configuring the PSD3XX for this type of application:

- Address inputs to the PSD3XX have to shift right by one. Address line A1 connects to AD0 pin of the PSD3XX and so on. For processors which have A0, A0 is no longer used as address input.
- Provide bank select signals to the appropriate PSD3XX for proper bank decoding. The even bank PSD3XX must include signal LDS/ as input to the PAD, and the odd bank PSD3XX requires the signal UDS/. These signals can be connected to Port C or the A19/CSI pin in order to be routed as PAD inputs.

- While inside the MAPLE software during PSD3XX configuration, the address map decode of the EPROM, SRAM, I/O port must also reflect the shift of the address inputs.
- The codes of the user's program have to be split into two files, one for the even bank PSD3XX and one for the odd bank PSD3XX.





PSD3XX

#### Benefits of 16-bit design with PSD3XX

PSD3XX Solution for 16-Bit Microcontroller with Non-Multiplexed Bus Figure 6 shows the address map of the odd bank PSD3XX. In the map table, the columns A19, A17, A16 are input signals of UDS, CS0 and CS1. Since this is the decoding for the odd bank, UDS (column A19) has to be low for any of the PSD3XX devices to be enabled.

Furthermore, the CS0 selects the EPROM and CS1 selects SRAM and I/O Port. The chip select logic of the 68302 also generates the programmed amount of wait state internally. The columns A15, A14, A13 in the address map are actually A16, A15 and A14 after the input address lines to the PSD3XX are shifted by one. Entries to the SEGMT START/STOP or FILE START/STOP columns must also change to relifect the shift of the address lines. For example, the top address of the EPROM (128K bytes) was 1FFFF, and is now 0FFFF after the shift.

Figure 6. Address Map, Odd Bank PSD3XX

|     | A<br>19 | A<br>18 | A<br>17 | A<br>16 | A<br>15 | A<br>14 | A<br>13 | A<br>12 | A<br>11 | SEGMT<br>START | SEGMT<br>STOP | FILE<br>START | FILE<br>STOP | FILE NAM |
|-----|---------|---------|---------|---------|---------|---------|---------|---------|---------|----------------|---------------|---------------|--------------|----------|
| ES0 | 0       | Х       | 0       | 1       | 0       | 0       | 0       | N       | N       |                |               | 0             | 1FFF         | ODD.HEX  |
| ES1 | 0       | Х       | 0       | 1       | 0       | 0       | 1       | Ν       | Ν       |                |               | 2000          | <b>3FFF</b>  | ODD.HEX  |
| ES2 | 0       | х       | 0       | 1       | 0       | 1       | 0       | Ν       | Ν       |                |               | 4000          | 4FFF         | ODD.HEX  |
| ES3 | 0       | х       | 0       | 1       | 0       | 1       | 1       | Ν       | Ν       |                |               | 6000          | 7FFF         | ODD.HEX  |
| ES4 | 0       | х       | 0       | 1       | 1       | 0       | 0       | Ν       | Ν       |                |               | 8000          | 9FFF         | ODD.HEX  |
| ES5 | 0       | х       | 0       | 1       | 1       | 0       | 1       | Ν       | Ν       |                |               | A000          | BFFF         | ODD.HEX  |
| ES6 | 0       | х       | 0       | 1       | 1       | 1       | 0       | Ν       | Ν       |                |               | C000          | DFFF         | ODD.HEX  |
| ES7 | 0       | х       | 0       | 1       | 1       | 1       | 1       | Ν       | Ν       |                |               | E000          | FFFF         | ODD.HEX  |
| RS0 | 0       | х       | 1       | 0       | 0       | 0       | 0       | 0       | 0       |                |               | N/A           | N/A          | N/A      |
| CSP | 0       | х       | 1       | 0       | 1       | 0       | 0       | 0       | 0       |                |               | N/A           | N/A          | N/A      |

ADDRESS MAP

FILE NAME, P3. P0, and ALE/AS. Use SPACEBAR to erase any field value. F1 – Return to Main Menu F2 – Temporary Exit to DOS F3 – Go to Help Cursor – UP:↑ Down:↓ Left Col: ← Right Col: → Right – F4 Left – F5

#### Conclusion

After going through the design examples with the PSD3XX, it is not difficult to see the advantages the PSD3XX family offers over designs with discrete ICs. Besides providing 16-bit performance, PSD3XX devices are able to replace 7 ICs in the 80C196 example. This not only reduces the board size dramatically but also provides benefits such as cost reduction in board manufacturing, higher product reliability, lower power consumption and reduced component cost. Other PSD3XX advantages over the discrete component design include the power down mode to reduce power consumption when the microcontroller is idle. The security feature protects the code stored in the EPROM from illegal copy. The flexibility, programmability, and ease of use which come with the PSD3XX truly make it an optimal solution for 16-bit embedded applications.

Philips Semiconductors

## Section 4 Development Systems

PSD3XX Programmable Microcontroller Peripherals

#### INDEX

| PSDGold/PSDSilver Development System451   |
|-------------------------------------------|
| WS6000 MagicPro® Memory                   |
| and Programmable Peripheral Programmer455 |

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

### PSD3XX





#### **Contents**

- MAPLE-MAP Locator editor.
- MAPPRO Interface software to MAP168 device programmer (MagicPro)
- Software user's manual

- UWS6000 MagicPro Programmer
- A Socket Adaptor and Two Product Samples

**PSDSilver** 



PSD3XX

#### Contents

- □ MAPLE-MAP Locator editor.
- MAPPRO Interface software to PSD100 device programmer (MagicPro)
- Software user's manual

| WS6015<br>Socket<br>Adaptor | The WS6015 is a socket adaptor that mounts on the MagicPro RSA and adapts | the PSD3XX or MAP168 in a 44-pin PGA package to the programmer.  |
|-----------------------------|---------------------------------------------------------------------------|------------------------------------------------------------------|
| WS6020<br>Socket<br>Adaptor | The WS6020 is a socket adaptor that mounts on the MagicPro RSA and adapts | the PSD3XX in a 52-pin PQFP package to the programmer.           |
| WS6021<br>Socket<br>Adaptor | The WS6021 is a socket adaptor that mounts on the MagicPro RSA and adapts | the PSD3XX in a 44 pin CLDCC or PLDCC package to the programmer. |

| Ordering<br>Information | Product   | Description                                                                                   |
|-------------------------|-----------|-----------------------------------------------------------------------------------------------|
|                         | PSDSilver | Contains PSD3XX and PSD100 Software (MAPLE-MAP and MAPPRO), Software User's Manual.           |
|                         | PSDGold   | Contains PSD-Silver, WS6000 MagicPro Programmer, a Socket<br>Adaptor and Two Product Samples. |

## MagicPro<sup>®</sup> Memory and Programmable Peripheral Programmer

### WS6000

#### **Key Features** Programs All CMOS Memory and Programmable Peripheral Products and all future Programmable Products

Programs 24, 28, 32 and 40 Pin Standard 600 Mil or Slim 300 Mil Dip Packages without Adaptors

#### *General Description*

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

The MagicPro plug-in board is integrated easily into the IBM-PC. It occupies a short expansion slot and its software requires only 256K bytes of computer memory. The two external ZIF-Dip sockets in the Remote

- Programs LCC, PGA and QFP Packaged Product by Using Adaptors
- Easy-to-Use Menu-Driven Software
- Compatible with IBM PC/XT/AT Family of Computers (and True Plug-Compatible

Socket Adaptor (RSA) support 24, 28, 32 and 40 pin standard 600 mil or slim 300 mil Dip packages without adaptors. LCC, PGA and QFP packages are supported using adaptors.

Many features of the MagicPro Programmer show its capabilities in supporting future products. Some of these are:

- 24 to 40 pin JEDEC Dip Pinouts
- 1 Meg Address Space (20 address lines)
- 16 Data I/O Lines



# MagicPro<sup>®</sup> Memory and Programmable Peripheral Programmer

| General<br>Description<br>(Cont.) | The MagicPro menu driven software<br>makes using different features of the<br>MagicPro an easy task. Software updates<br>are done via floppy disk which eliminates<br>the need for adding a new memory device<br>for system upgrading.                                                                                        | The MagicPro reads Intel Hex format for use with assemblers and compilers.                                                                                                                                                                                                                                                                                                                        |
|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MagicPro<br>Commands              | <ul> <li>Help</li> <li>Upload RAM from Device</li> <li>Load RAM from Disk</li> <li>Write RAM to Disk</li> <li>Display RAM Data</li> <li>Edit RAM</li> <li>Move/Copy RAM</li> </ul>                                                                                                                                            | <ul> <li>Fill RAM</li> <li>Blank Test Device</li> <li>Verify Device</li> <li>Program Device</li> <li>Select Device</li> <li>Configuration</li> <li>Quit MagicPro</li> </ul>                                                                                                                                                                                                                       |
| Technical<br>Information          | <ul> <li>Size:<br/>IBM-PC Short Length Card</li> <li>Port Address Location:<br/>100H to 1FFH – default 140H (if a conflict exists with this address space, the address location can be changed in software and with the switches on the plug-in board.)</li> <li>System Memory Requirements:<br/>256K Bytes of RAM</li> </ul> | Remote Socket Adaptor (RSA):<br>The RSA contains two ZIF-Dip sockets<br>that are used to program and read WSI<br>programmable products. The 32 pin<br>ZIF-Dip socket supports 24, 28 and 32<br>pin standard 600 mil or slim 300 mil<br>Dip packaged product. The 40 pin<br>ZIF-Dip socket supports all 40 pin Dip<br>packages. Adaptor sockets are<br>available for LCC, PGA and QFP<br>packages. |

WS6000

D Power:

.

+ 5 Volts, 0.03 Amp; +12 Volts, 0.04 Amp

# MagicPro® Memory and Programmable Peripheral Programmer

| <ul> <li>The WS6000 MagicPro System Contains:</li> <li>MagicPro IBM-PC Plug-in Programmer Board</li> <li>MagicPro Remote Socket Adaptor and Cable</li> <li>MagicPro Operating System Floppy Disk and Operating Manual</li> </ul> |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| The WS6000 MagicPro Adaptors Include:                                                                                                                                                                                            |  |  |  |
| WS6023 100-Pin PQFP Package<br>Adaptor for PAC1000                                                                                                                                                                               |  |  |  |
| WS6024 28-Pin CLLCC Package<br>Adaptor for Memory                                                                                                                                                                                |  |  |  |
| WS6025 32-Pin PLDCC/CLDCC                                                                                                                                                                                                        |  |  |  |
| Package Adaptor for Memory<br>(WS57C51B/C Only)                                                                                                                                                                                  |  |  |  |
| WS6026 32-Pin CLLCC<br>Package Adaptor for Memory                                                                                                                                                                                |  |  |  |
| (WS57C51B/C Only)<br>WS6027 32-Pin PLDCC/CLDCC                                                                                                                                                                                   |  |  |  |
| Package Adaptor for Memory<br>(WS57C71C Only)                                                                                                                                                                                    |  |  |  |
| WS6028 32-Pin CLLCC<br>Package Adaptor for Memory<br>(WS57C71C Only)                                                                                                                                                             |  |  |  |
|                                                                                                                                                                                                                                  |  |  |  |

· .

Philips Semiconductors

## Section 5 Package Outlines

PSD3XX Programmable Microcontroller Peripherals

#### INDEX

| J2 | 44-Pin Plastic Leaded Chip Carrier (PLCC)46                               |     |
|----|---------------------------------------------------------------------------|-----|
| L4 | 44-Pin Ceramic Leaded Chip Carrier (CLCC)<br>with Window (Package Type L) | 462 |
| Q2 | 52-Pin Plastic Quad Flatpack (PQFP)                                       |     |

1 , **a** 

# **Package Outlines**



|        |             | Family | : Plastic Lead | ded Chip Carri | er     |           |
|--------|-------------|--------|----------------|----------------|--------|-----------|
|        | Millimeters |        |                | Inches         |        |           |
| Symbol | Min         | Max    | Notes          | Min            | Max    | Notes     |
| A      | 4.19        | 4.57   |                | 0.165          | 0.180  |           |
| A1     | 2.54        | 2.79   |                | 0.100          | 0.110  |           |
| A2     | 3.76        | 3.96   |                | 0.148          | 0.156  |           |
| В      | 0.33        | 0.53   |                | 0.013          | 0.021  |           |
| B1     | 0.66        | 0.81   |                | 0.026          | 0.032  |           |
| С      | 0.246       | 0.262  |                | 0.0097         | 0.0103 |           |
| D      | 17.40       | 17.65  |                | 0.685          | 0.695  |           |
| D1     | 16.51       | 16.61  |                | 0.650          | 0.654  |           |
| D2     | 14.99       | 16.00  |                | 0.590          | 0.630  |           |
| D3     | 12.70       |        | Reference      | 0.500          |        | Reference |
| E      | 17.40       | 17.65  |                | 0.685          | 0.695  |           |
| E1     | 16.51       | 16.61  |                | 0.650          | 0.654  |           |
| E2     | 14.99       | 16.00  |                | 0.590          | 0.630  |           |
| E3     | 12.70       |        | Reference      | 0.500          |        | Reference |
| e1     | 1.27        |        | Reference      | 0.050          |        | Reference |
| N      | 44          |        |                | 44             |        |           |

## **Package Outlines**



|        | Fa          | amily: Cei | ramic Leaded | Chip Carrier-C | ERQUAD |                                                                                                                 |
|--------|-------------|------------|--------------|----------------|--------|-----------------------------------------------------------------------------------------------------------------|
|        | Millimeters |            |              | Inches         |        |                                                                                                                 |
| Symbol | Min         | Max        | Notes        | Min            | Max    | Notes                                                                                                           |
| A      | 3.94        | 4.57       |              | 0.155          | 0.180  |                                                                                                                 |
| A1     | 2.29        | 2.92       |              | 0.095          | 0.115  |                                                                                                                 |
| A2     | 3.05        | 3.68       |              | 0.120          | 0.145  |                                                                                                                 |
| В      | 0.43        | 0.53       |              | 0.017          | 0.021  |                                                                                                                 |
| B1     | 0.66        | 0.81       |              | 0.026          | 0.032  |                                                                                                                 |
| С      | 0.15        | 0.25       |              | 0.006          | 0.010  |                                                                                                                 |
| D      | 17.40       | 17.65      |              | 0.685          | 0.695  |                                                                                                                 |
| D1     | 16.31       | 16.66      |              | 0.642          | 0.656  |                                                                                                                 |
| D2     | 14.99       | 16.00      |              | 0.590          | 0.630  |                                                                                                                 |
| D3     | 12.70       |            | Reference    | 0.500          |        | Reference                                                                                                       |
| E      | 17.40       | 17.65      |              | 0.685          | 0.695  | 1998 - 1999 - 1999 - 1999 - 1999 - 1999 - 1999 - 1999 - 1999 - 1999 - 1999 - 1999 - 1999 - 1999 - 1999 - 1999 - |
| E1     | 16.31       | 16.66      |              | 0.642          | 0.656  |                                                                                                                 |
| E2     | 14.99       | 16.00      |              | 0.590          | 0.630  |                                                                                                                 |
| E3     | 12.70       |            | Reference    | 0.500          |        | Reference                                                                                                       |
| e1     | 1.27        |            | Reference    | 0.050          |        | Reference                                                                                                       |
| N      | 44          |            |              | 44             |        | 1                                                                                                               |

## Package Outlines

-----

Q2 52-PIN PLASTIC QUAD FLATPACK (PQFP)



|        |             | Far   | nily: Plastic Q | uad Flatpack |       |           |
|--------|-------------|-------|-----------------|--------------|-------|-----------|
|        | Millimeters |       |                 | Inches       |       |           |
| Symbol | Min         | Max   | Notes           | Min          | Max   | Notes     |
| α      | 00          | 80    |                 | 00           | 80    |           |
| A      | 2.55        | 3.05  |                 | 0.100        | 0.120 |           |
| A1     | 0.00        | 0.25  |                 | 0.000        | 0.010 |           |
| A2     | 2.55        | 2.80  |                 | 0.100        | 0.110 |           |
| В      | 0.35        | 0.50  |                 | 0.014        | 0.020 |           |
| С      | 0.13        | 0.23  |                 | 0.005        | 0.009 |           |
| D      | 17.65       | 18.15 |                 | 0.695        | 0.715 |           |
| D1     | 13.95       | 14.05 |                 | 0.549        | 0.553 |           |
| D3     | 12.00       |       | Reference       | 0.472        |       | Reference |
| E      | 17.65       | 18.15 |                 | 0.695        | 0.715 |           |
| E1     | 13.95       | 14.05 |                 | 0.549        | 0.553 |           |
| E3     | 12.00       |       | Reference       | 0.472        |       | Reference |
| e1     | 1.00        |       | Reference       | 0.0394       |       | Reference |
| L      | 0.65        | 0.95  |                 | 0.026        | 0.037 | 1         |
| N      | 52          |       |                 | 52           |       |           |

Q2

Philips Semiconductors

Section 6 Sales Offices, Representatives & Distributors

PSD3XX Programmable Microcontroller Peripherals , isi

PHILIPS

ALABAMA

Elcom, inc.

ARIZONA

Scottedale

Calabasas

Orangevale

San Diego

San Jose

Sunnyvale

COLORADO

Englewood

Wallingford JEBCO

**FLORIDA** 

GEORGIA

Oviedo

Atlanta

Norcross

ILLINOIS

Elcom, Inc.

Irvine

CALIFORNIA

Huntsville

## Sales Offices, Representatives and Distributors

Itasca SEMICONDUCTORS 811 East Arques Avenue INDIANA P.O. Box 3409 Sunnyvale, CA 94088-3409 Kokomo **Philips Semiconductors** Phone: (205) 464-0111 MARYLAND Phone: (205) 830-4001 Columbia Thom Luke Sales, Inc. Phone: (602) 541-5400 Chelmsford JEBCO Westford Philips Semiconductors Phone: (818) 880-6304 Philips Semiconductors Phone: (714) 833-8980 (714) 752-2780 MICHIGAN Monroe Novi Webster Associates Phone: (916) 989-0843 MINNESOTA Philips Semiconductors Phone: (619) 560-0242 Bloomington B.A.E. Sales, Inc. Phone: (408) 452-8133 MISSOURI Bridgeton Centech, Inc. Philips Semiconductors Phone: (408) 991-3737 Raytown Centech, Inc. Philips Semiconductors **NEW JERSEY** Phone: (303) 792-9011 Toms River Thom Luke Sales, Inc. Phone: (303) 649-9717 CONNECTICUT **NEW YORK** ithaca Phone: (203) 265-1318 **Rockville Centre** Conley and Assoc., Inc. Phone: (407) 365-3283 Philips Semiconductors Phone: (404) 594-1392 Matthews Phone: (404) 447-8200 ADI, Inc. Smithfield **Hoffman Estates** Micro-Tex, Inc. Phone: (708) 765-3000

Philips Semiconductors Phone: (708) 250-0050 Indianapolis Mohrfield Marketing, Inc. Phone: (317) 546-6969 Philips Semiconductors Phone: (317) 459-5355 Third Wave Solutions, Inc. Phone: (301) 290-5990 MASSACHUSETTS Phone: (508) 256-5800 Philips Semiconductors Phone: (508) 692-6211 S-J Associates Phone: (313) 242-0450 Philips Semiconductors Phone: (313) 347-1400 High Technology Sales Phone: (612) 844-9933 Phone: (314) 291-4230 Phone: (816) 358-8100 Philips Semiconductors Phone: (908) 505-1200 Bob Dean, Inc. Phone: (607) 257-1111 S-J Associates Phone: (516) 536-4242 Wappingers Falls Philips Semiconductors Phone: (914) 297-4074 Bob Dean, Inc. Phone: (914) 297-6406 NORTH CAROLINA Phone: (704) 847-4323 ADI, Inc. Phone: (919) 934-8136

OHIO Aurora S-J Associates, Inc. Phone: (216) 562-2050

Columbus S-J Associates, Inc. Phone: (614) 885-6700

Kettering S-J Associates, Inc. Phone: (513) 298-7322

Parma S-J Associates, Inc. Phone: (216) 888-7004

West Carroliton S-J Associates, Inc. Phone: (513) 438-1700

OREGON **Beaverton Philips Semiconductors** Phone: (503) 627-0110

> Western Technical Sales Phone: (503) 644-8860

PENNSYLVANIA Erie

S-J Associates, Inc. Phone: (216) 888-7004

Hatboro Delta Technical Sales, Inc. Phone: (215) 957-0600

Pittsburgh S-J Associates, Inc. Phone: (216) 888-7004

Plymouth Meeting Philips Semiconductors Phone: (215) 825-4404

TENNESSEE Greeneville Philips Semiconductors Phone: (615) 639-0251

TEXAS Austin Philips Semiconductors Phone: (512) 339-9945

Austin Synergistic Sales, Inc. Phone: (512) 346-2122

Houston Synergistic Sales, Inc. Phone: (713) 937-1990 Richardson

Philips Semiconductors Phone: (214) 644-1610

Richardson Synergistic Sales, Inc. Phone: (214) 644-3500

UTAH Salt Lake City Electrodyne Phone: (801) 264-8050 WASHINGTON Bellevue

Western Technical Sales Phone: (206) 641-3900 Spokane Western Technical Sales Phone: (509) 922-7600

WISCONSIN Waukesha Micro-Tex. Inc. Phone: (414) 542-5352

#### CANADA PHILIPS SEMICONDUCTORS CANADA, LTD.

Calgary, Alberta Tech-Trek, Ltd. Phone: (403) 241-1719

Kanata, Ontario Philips Semiconductors Phone: (613) 599-8720 Tech-Trek, Ltd.

Phone: (613) 599-8787

Mississauga, Ontario Tech-Trek, Ltd. Phone: (416) 238-0366

Richmond, B.C. Tech-Trek, Ltd Phone: (604) 276-8735

Ville St. Laurent, Quebec Tech-Trek, Ltd. Phone: (514) 337-7540

MEXICO Anzures Section Philips Components Phone: 52-5-533-3858

El Paso, TX Philips Components Phone: (915) 775-4200

**PUERTO RICO** Santurce Mectron Group Phone: (809) 723-6165

#### DISTRIBUTORS

Contact one of our local distributors: Almac/Arrow Electronics Anthem Electronics Arrow/Schweber Electronics Falcon Electronics, Inc. Gerber Electronics Hamilton/Avnet Electronics Marshall Industries Wyle/EMG Zentronics, Ltd.

4/15/93





### Philips Semiconductors — a worldwide company

Argentina: IEROD, Av. Juramento 1991 - 14.B (1428) BUENOS AIRES, Tel. (541) 541 4261/541 4106, Fax (541) 786 7635 Australia: 34 Waterloo Road, NORTH RYDE, NSW 2113, Tel. (02) 805-4455, Fax. (02) 805 4466 Austria: Triester Str. 64, A-1101 WIEN, P.O. Box 213, Tel. (01) 60 101-1236, Fax. (01) 60101-1211 Belgium: 80 Rue Des Deux Gares, B-1070 BRUXELLES, Tel. (02) 525 6111, Fax. (02) 525 7246 Brazil: Rua do Rocia 220 - 5th Floor, CEP: 04552-000 SAO PAULO-SP, Brazil P.O. Box 7383-CEP-01051 Tel. (011) 829-1166, Fax (011) 829-1849 Canada: INTEGRATED CIRCUITS Tel. (800) 234-7381, Fax. (708) 296-8556 DISCRETE SEMICONDUCTORS: 601 Milner Ave., SCARBOROUGH, ONTARIO, M1B 1M8 Tel. (0416) 292-5161 ext. 2336, Fax (0416) 292-4477 Chile: Av. Santa Maria 0760, SANTIAGO, Tel. (02) 773 816, Fax (02) 777 6730 Colombia: Carrera 21 No. 56-17, BOGOTA, D.E., P.O. Box 77621, Tel. (01) 249 7624, Fax (01) 217 4549 Denmark: Prags Boulevard 80, PB 1919, DK-2300 COPENHAGEN S. Tel. (032) 88 2636, Fax. (031) 57 1949 Finland: Sinikalliontie 3, SF-02630 ESPOO, Tel. (9) 50261, Fax. (9) 520971 France: 4 rue du Port-aux-Vins, BP317 92156 SURESNES Cedex Tel. (01)4099 8161, Fax, (01)4099 8536 Germany: Burchardstrasse 19, D-2 HAMBURG 1, Tel. (040) 3296-0, Fax. (040) 3296 213 Greece: No. 15, 25th March Street, GR 17778 TAVROS, Tel. (01) 4894 339/4894 911, Fax (01) 4814 240 Hong Kong: 15/F Philips Ind. Bldg., 24-28 Kung Yip St., KWAI CHUNG, Tel. (0)42 45 121, Fax. (0) 48 06 960 India: PEICO ELECTRONICS & ELECTRICALS LTD., Components Dept., Shivsagar Estate, Block 'A Dr. Annie Besant Rd., Worli, BOMBAY-400 018, Tel. (022) 49 38 541, Fax. (022) 4938 722 Indonesia: Philips House, Jalan H.R. Rasuna Said Kav. 3-4, P.O. Box 4252, JAKARTA 12950 Tel. (021) 5201 122, Fax (021) 5205 189 Ireland: Newstead, Clonskeagh, DUBLIN 14, Tel. (01) 640 000, Fax. (01) 640 200 Italy: V. Le F. Testi, 327, 20162-MILANO, Tel. (02) 6752.1, Fax. (02) 6752 3350 Japan: Philips Bldg. 13-37, Kohnan 2-chome, Minato-ku, TOKYO 108, Tel. (03) 3740 5101, Fax. (03) 37400 570 Korea (Republic of): Philips House, 260-199 Itaewon-dong, Yongsan-ku, SEOUL, Tel. (02) 794 5011, Fax. (02) 798 8022 Malaysia: No. 76 Jalan Universiti, 46200 PETALING JAYA, SELANGOR, Tel. (03) 7755 1088, Fax. (03) 757 4880 Mexico: Philips Components, 6D Founder Blvd., El Paso, TX 79906 Tel. 9-5- (800) 234-7381, Fax. (708) 296-8556 Netherlands: Postbus 90050, 5600 PB EINDHOVEN, Tel. (040) 78 37 49, Fax. (040) 78 83 99 New Zealand: 2 Wagener Place, C.P.O. Box 1041, AUCKLAND, Tel. (09) 894-4180, Fax. (09) 849-7811 Norway: Box 1, Manglerud 0612, OSLO, Tel. (22) 74 8000, Fax (22) 74 8341 Pakistan: Philips Markaz, M.A. Jinnah Rd., KARACHI-3, Tel. (021) 577 039, Fax (021) 569 1832

9398 652 55011

Philips Semiconductors

Peru: Carretera Central 6.500, LIMA 3, Apartado 5612, Tel. (014) 468 999/468 949

Philippines: PHILIPS SEMICONDUCTORS PHILIPPINES Inc., 106 Valero St. Salcedo Village, P.O. Box 911, MAKATI, Metro MANILA, Tel. (02) 810 0161, Fax. (02) 817 3474

Portugal: Av. Eng. Duarte Pacheco 6, 1009 LISBOA Codex, Tel. (01) 68 31 21, Fax. (01) 65 80 13

Singapore: Lorong 1, Toa Payoh, SINGAPORE 1231, Tel. (65) 35 02 000, Fax. (65) 25 16 500

South Africa: 195-215 Main Road, Martindale, P.O. Box 7430, JOHANNESBURG 2000, Tel. (011) 470-5433, Fax. (011) 470-5494

Spain: Balmes 22, 08007 BARCELONA, Tel. (93) 301 63 12. Fax. (93) 301 42 43

Sweden: Kotibygatan 7, Akalla. Post: S-164 85 STOCKHOLM, Tel. (0)8-6321 2000, Fax. (0)8-632 2745

Switzerland: Alimendstrasse 140-142, CH-8027 ZÜRICH, Tel. (01) 488 22 11, Fax. (01) 482 85 95

Talwan: 69, Min Sheng East Road, Sec. 3, P.O. Box 22978, TAIPEI 10446, Tel. (2) 509 7666, Fax. (2)500 5899

Thalland: PHILIPS ELECTRONICS THAILAND Ltd. 60/14 MOO 11, BANGNA - Trad Road Km. 3 Prakanong, BANGKOK 10260 Tel. (2) 399 3280 to 8, (2) 398 2083, Fax (2) 398 2080

Turkey: Talatpasa Cad. No. 5, 80640 LEVENT/ISTANBUL, Tel. (01) 279 2770, Fax. (01) 269 3094

United Kingdom: Philips Semiconductors Limited, P.O. Box 65, Philips House, Torrington Place, LONDON WC1E 7HD, Tel. (071) 436 4144, Fax. (071) 323 0342

United States: INTEGRATED CIRCUITS: 811 East Argues Avenue, SUNNYVALE, CA 94088-3409, Tel. (800) 294-7381, Fax. (708) 296-8556 DISCRETE SEMICONDUCTORS: 2001 West Blue Heron Bivd., PO: Box 10330, RIVIERA BEACH, FLORIDA 33404, Tel. (800) 447-3762 and (407) 881-3200, Fax. (407) 881-3300

Uruguay: Coronel Mora 433, MONTEVIDEO, Tel. (02) 70 4044, Fax (02) 92 0601

Venezuela: Calle 6, Ed. Las Tres Jotas, CARACAS 1074A, App. Post. 78117, Tel. (02) 241 7509, Fax (02) 241 4518

For all other countries apply to: Philips Semiconductors, International Marketing and Sales, Building BAF-1, PO. Box 218, 5600 MD EINDHOVEN, The Netherlands, Telex 35000 phtoni, Fax +31:40-724825 SCD19 @Philips Electronics B.V. 1993

All rights are reserved. Reproduction in whole or in part is prohibited without the prior written consent of the copyright owner.

The information presented in this document does not form part of any quotation or contract, is believed to be accurate and reliable and may be changed without notice. No liability will be accupted by the publisher for any consequence of its use. Publication thereof does not convey nor imply any license under patent — or industrial or intellectual property rights. Printian the USA Date of release: 0583

98-8080-800 3089M/30M/FP/0693 476pp



